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

前端之家收集整理的这篇文章主要介绍了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>

猜你在找的asp.Net相关文章