IIS中的Asp.Net核心MVC应用程序Windows身份验证

我的Asp.Net Core mvc Web应用程序需要Windows身份验证.在开发中,在IIS Express上,由于这个设置,一切正常

launchSettings.json

"iisSettings": {
    "windowsAuthentication": true,"anonymousAuthentication": false,"iisExpress": {
      "applicationUrl": "http://localhost:61545/","sslPort": 0
    }
  }

部署到IIS时,我得到一个空白页面.对我的网站的请求获得500错误代码.

我尝试将此配置添加到Startup.cs,如here所述,但没有成功.

services.Configure<IISOptions>(options => {
        options.ForwardWindowsAuthentication = true;
    });

当我直接在IIS中查看身份验证参数时,将激活Windows身份验证.

我发现一些帖子谈论了一个名为Microsoft.AspNetCore.Server.WebListener的软件包,其他一些关于实现自定义中间件的软件包.我无法想象这个基本功能需要付出那么多努力.我错过了什么吗?

解决方法

launchSettings.json文件仅供VS使用.当您发布应用程序(或在没有VS的情况下运行)时,不会使用launchSettings.json.使用IIS / IISExpress运行时,只需确保web.config具有正确的设置.在您的情况下,web.config中的forwardWindowsAuthToken属性丢失或设置为false.必须将其设置为true才能使Windows身份验证生效.发布前的示例web.config如下所示:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webServer>
    <handlers>
      <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified"/>
    </handlers>
    <aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="true"/>
  </system.webServer>
</configuration>

相关文章

引言 本文从Linux小白的视角, 在CentOS 7.x服务器上搭建一个...
引言: 多线程编程/异步编程非常复杂,有很多概念和工具需要...
一. 宏观概念 ASP.NET Core Middleware是在应用程序处理管道...
背景 在.Net和C#中运行异步代码相当简单,因为我们有时候需要...
HTTP基本认证 在HTTP中,HTTP基本认证(Basic Authenticatio...
1.Linq 执行多列排序 OrderBy的意义是按照指定顺序排序,连续...