5

我记得,我曾经使用以下代码获取登录用户 ID(用于 Intranet 应用程序):-

string WindowsLoginID= System.Web.HttpContext.Current.Request.ServerVariables["AUTH_USER"];// This is blank

当我在 ASP 应用程序后面的代码中使用它时,它仍然可以正常工作。但是当我在其中使用相同的代码时,MVC4 Application它会返回我blank

我正在运行我的项目Use Local IIS Web Server,我的 web.config 我有 -

<authentication mode="Windows">
</authentication>

请让我知道,如果我在做一些愚蠢的事情。

4

2 回答 2

8

我缺少一些配置,我创建了一个新的 MVC Intranet 应用程序并进行了如下设置更改:-

在 IIS Express 上托管:

  1. 在解决方案资源管理器中单击您的项目以选择该项目。
  2. 如果“属性”窗格未打开,请将其打开 (F4)。
  3. 在项目的“属性”窗格中:

    a) 将“匿名验证”设置为“禁用”。

    b) 将“Windows 身份验证”设置为“启用”。

在 IIS 7 或更高版本上托管:

  1. 打开 IIS 管理器并导航到您的网站。
  2. 在功能视图中,双击身份验证。
  3. 在身份验证页面上,选择 Windows 身份验证。如果 Windows 身份验证不是一个选项,您需要确保在服务器上安装了 Windows 身份验证。

    要在 Windows 上启用 Windows 身份验证:

    a) 在控制面板中打开“程序和功能”。

    b) 选择“打开或关闭 Windows 功能”。

    c) 导航到 Internet 信息服务 > 万维网服务 > 安全并确保选中 Windows 身份验证节点。

    要在 Windows Server 上启用 Windows 身份验证:

    a) 在服务器管理器中,选择 Web 服务器 (IIS) 并单击添加角色服务。

    b) 导航到 Web 服务器 > 安全并确保选中 Windows 身份验证节点。

  4. 在“操作”窗格中,单击启用以使用 Windows 身份验证。

  5. 在身份验证页面上,选择匿名身份验证。
  6. 在“操作”窗格中,单击禁用以禁用匿名身份验证。

来源:- MVC Intranet Application 的 readme.txt

于 2013-09-18T07:55:28.393 回答
6

Properties pane您的项目中:

a) 设置"Anonymous Authentication"为“禁用”。

b) 设置"Windows Authentication"为“启用”。

希望能帮助到你!

于 2013-09-18T08:11:43.010 回答