Sam*_*Sam 5 asp.net active-directory windows-authentication
我正在维护一个查询Active Directory的旧版ASP.NET 3.5应用程序.该应用程序使用"集成Windows身份验证",旨在使用自己的安全上下文而不是专用的用户名和密码连接到Active Directory.
这是相关的代码.
using (DirectoryEntry root = new DirectoryEntry())
using (DirectorySearcher searcher = new DirectorySearcher(root))
{
searcher.Filter = string.Format("(&(samAccountName={0})(objectClass=user)(objectCategory=person))", userName.Trim());
SearchResultCollection results = searcher.FindAll();
}
Run Code Online (Sandbox Code Playgroud)
虽然它使用ASP.NET 3.5,但由于现有的基础结构限制,它需要从ASP.NET 4.0应用程序池中运行.
FindAll在某些情况下调用抛出以下异常:
System.DirectoryServices.DirectoryServicesCOMException(0x80072020):发生操作错误.
当我使用Visual Studio调试器检查异常对象时,该ExtendedErrorMessage属性包含更详细的信息:
000004DC:LdapErr:DSID-0C0906E8,注释:为了执行此操作,必须在连接上完成成功绑定.,data 0,v1db1
以下屏幕截图显示了Visual Studio调试器中的内容:

我找到了一些解决方法来完成这项工作,但我不能接受它们:
我从互联网上找到了一些建议,但没有一个完全解决了这个问题:
HostingEnvironment.Impersonate().我想在不必重新配置Active Directory中的任何内容的情况下完成这项工作.它在某些IIS配置下工作正常,如上所示,所以我认为应该可以通过重新配置应用程序或IIS(除了更改.NET框架版本)来使其工作.
我相信这个问题有多种原因:
要解决第二个问题,请将应用程序升级到 ASP.NET 4.0 或将 IIS 配置为使用 ASP.NET 2.0。
| 归档时间: |
|
| 查看次数: |
8149 次 |
| 最近记录: |