从ASP.NET应用程序使用Active Directory时,DirectoryServicesCOMExceptio
介绍 我正在维护一个查询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身份验证,而不是使用基本身份验证. 什么行不通 我从互联网上找到了一些建议,但没有一个完全解决了这个问题: >使用HostingEnvironment.Impersonate(). 我想要的是 我想在不必重新配置Active Directory中的任何内容的情况下完成这项工作.它在某些IIS配置下工作正常,如上所示,所以我认为应该可以通过重新配置应用程序或IIS(除了更改.NET框架版本)来使其工作. 解决方法我认为问题有多种原因:>使用ASP.NET模拟. 要解决第二个问题,请将应用程序升级到ASP.NET 4.0或将IIS配置为使用ASP.NET 2.0. (编辑:4S站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 什么是在asp.net中301重定向更推荐的方法?
- ASP.NET代码隐藏中的当前工作目录 – 我们可以依
- 如何在ASP.NET 5中添加一个TypeScript绝对类型的
- Asp.NetCore1.1版本去掉project.json后如何打包生
- asp.net core标签助手的高级用法TagHelper+Form
- asp.net – 查询字符串参数使我的应用程序面临风
- 为ASP.NET应用程序实现后台服务的最佳方法是什么
- asp.net-mvc-3 – 为什么@ Html.Label()删除一些
- asp.net – 如何使用Fiddler编辑HTTP请求
- asp.net-mvc – 在ASP.NET MVC中的LinkButton