大佬教程收集整理的这篇文章主要介绍了从ASP.NET应用程序使用Active Directory时,DirectoryServicesCOMException(0x80072020),大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在维护一个查询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(); }
虽然它使用ASP.NET 3.5,但由于现有的基础结构限制,它需要从ASP.NET 4.0应用程序池中运行.
问题
在某些情况下,对FindAll的调用会引发以下异常:
当我使用Visual studio调试器检查异常对象时,ExtendedErrormessage属性包含更详细的信息:
以下屏幕截图显示了Visual studio调试器中的内容:
什么有用
我找到了一些解决方法来完成这项工作,但我不能接受它们:
>禁用集成Windows身份验证,而不是使用基本身份验证.
>在IIS中,在ASP.NET 2.0下运行应用程序,并禁用网络服务帐户和ASP.NET模拟.
>仅使用localhost作为主机名从Web服务器访问应用程序.
>在web.config中使用带有硬编码帐户的ASP.NET模拟.
什么行不通
我从互联网上找到了一些建议,但没有一个完全解决了这个问题:
>使用HosTingEnvironment.Impersonate().
>禁用假冒.
我想要的是
我想在不必重新配置Active Directory中的任何内容的情况下完成这项工作.它在某些IIS配置下工作正常,如上所示,所以我认为应该可以通过重新配置应用程序或IIS(除了更改.NET框架版本)来使其工作.
>使用ASP.NET模拟.
>在ASP.NET 4.0应用程序池下运行ASP.NET 3.5应用程序.
要解决第二个问题,请将应用程序升级到ASP.NET 4.0或将IIS配置为使用ASP.NET 2.0.
以上是大佬教程为你收集整理的从ASP.NET应用程序使用Active Directory时,DirectoryServicesCOMException(0x80072020)全部内容,希望文章能够帮你解决从ASP.NET应用程序使用Active Directory时,DirectoryServicesCOMException(0x80072020)所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。