IIS7上的ASP.NET身份验证问题 – 对于Windows身份验证,User.Iden
我们在ASP.NET 4.0上使用MVC 3使用
Windows身份验证的ASP.NET应用程序.
从Visual Studio 2010运行时,一切都按预期工作,但当推出到IIS7时,Windows登录用户永远不会被填充(检查User.Identity.Name).也没有出现用户凭据的对话框提示. web.config设置: <authentication mode="Windows" /> 在IIS中,我可以看到启用了Windows身份验证,Anonymous也是如此(禁用Anonymous导致403 Forbidden并且没有显示任何内容). 我已尝试启用和禁用“内核模式身份验证”(useKernelMode =“true”),但这似乎没有任何区别.虽然我确实记得我们必须在不同服务器上的另一个站点上禁用此设置,以使身份验证正常工作(可能指向堆栈中的潜在问题?). 如果它有用,来自IIS的applicationHost.config: <security> <authentication> <anonymousAuthentication enabled="true" /> <digestAuthentication enabled="false" /> <basicAuthentication enabled="false" /> <windowsAuthentication enabled="true" useKernelMode="false"> <providers> <clear /> <add value="NTLM" /> </providers> </windowsAuthentication> </authentication> </security> 任何想法可能是什么问题? 在此先感谢您的任何建议. 更新1 我设法找到另一个IIS7服务器进行测试,我发现如果我禁用匿名访问一切按预期工作.但是,即使我禁用匿名访问,我仍然在原始IIS7服务器上存在问题(我现在禁用匿名).所以我认为必须在堆栈中进一步存在一些问题.有任何想法吗?我需要修理的东西,因为它会不断弹出并咬我们想象. 更新2 如果我在问题IIS7框上启用摘要式身份验证,那么我将面临登录提示对话框的挑战,如果我提供合适的凭据,一切都按预期工作.但作为一个内部网络应用程序,用户已经登录到域,我们真的不想以这种方式挑战他们.凭据应该透明地传递,因为它在第二个IIS7框上工作. 更新3 一些进展……我发现如果Web应用程序位于根目录而不是子站点,那么直接编辑IIS7的applicationHost.config文件以提供以下身份验证设置,可以使站点按预期工作: <authentication> <anonymousAuthentication enabled="false" /> <windowsAuthentication enabled="true"> <providers> <clear /> <add value="NTLM" /> </providers> </windowsAuthentication> <digestAuthentication enabled="false" /> </authentication> 使用IIS7的UI配置身份验证并不能提供正确的结果.在病房之后缺少身份验证项目(因为我猜IIS7假定它们被继承)或者它们的设置错误(windowsAuthentication似乎需要上面的提供程序配置才能正常工作). 不幸的是,有问题的Web应用程序实际上是一个子应用程序,因为它有一个内部版本(使用Windows身份验证> www.site.com/internal)和外部版本(使用表单身份验证> www.site.com/external).我仍然无法将身份验证作为子应用程序工作.我只得到一个“错误代码:403 Forbidden”. 解决方法
在这种情况下,它是Microsoft ISA Server问题.似乎请求正在通过ISA内部路由到Windows Authenticated站点,一旦ISA被删除,问题就消失了.
我不太了解ISA以及它如何路由请求,但我认为它必须从请求中删除一些重要信息,因为某些规则会有人配置. 作为附注,如果它有助于诊断类似的设置:网络管理员告诉我内部流量没有通过ISA路由,但内部ping网站显示ISA实际上在播放. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-core – 如何在部署插槽交换后优雅地迁移打开的Web
- asp.net – 在global.asax中注册并使用Unity的记录器
- asp.net-mvc – 如何忽略ASP.NET MVC 4中特定View文件夹或特
- ASP.Net便携式服务器
- 使用ASP.NET Web API 2.1配置依赖注入
- 如何在asp.net mvc 3中禁用浏览器缓存?
- ASP.NET Core知多少(7):对重复编译说NO -- dotnet watch
- asp.net-mvc – Autofac(MVC EF SignalR Hangfire)生命周期
- ASP.NET MVC 3数据注释:动态添加验证
- ASP.NET bin目录中的Oracle oci.dll无法删除/不起作用
- asp.net-mvc – MVC DropDownListFor在视图中基本
- asp.net – IIdentity,IPrincipal,OWIN,Identity
- ASP.NET:编译器失败,错误代码为-532462766
- 如何使用ASP.NET C#设置html输入类型文本值?
- asp.net – EF,UoW和Repository – 何时在WebFor
- MVC 3指定远程验证的验证触发器
- asp.net-mvc – 用于ASP.NET MVC 3中用户帐户注册
- ASP.NET Core 使用 Redis 实现分布式缓存:Docke
- asp.net-mvc – 什么是FTP部署asp.net mvc网站的
- ASP.NET SiteMap – 有没有办法以编程方式查看它