从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. (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net – 来自.Net iSeries Provider的AS 400性能
- asp.net – 如何使用javascript生成假回发?
- asp.net – WebBrowsable vs个性化Web部件
- asp.net – Ajax上的Identity Server 3 – 401而不是302
- asp.net-mvc – .Net 4.5.1框架的maxRequestLength
- asp.net Web.config 详细配置说明
- 进程是经典ASP可以存储会话状态的唯一方法吗?
- asp.net – 什么是system.globalization它和本地化有什么区
- asp.net – 如何使用AntiXss Library正确清理内容?
- 充分利用ASP.NET的三种缓存提高站点性能的注意方法
- asp.net-mvc – 在IIS Express中测试SignalR应用
- ASP.NET通过自定义函数实现对字符串的大小写切换
- 具有多个ASP.NET Web应用程序的Visual Studio解决
- webforms – ASP.Net Core 1.0是否支持WebForm项
- asp.net-web-api – MaxExpansionDepth,带有最新
- asp.net-mvc – 使用MVC3剃刀的ASP.Net图表控件
- iis-7.5 – 使用虚拟目录/应用程序在IIS中托管AS
- asp.net-core – 如何使用FluentValidation.AspN
- azure – 当用户存储在外部身份提供程序服务中时
- vs2008试用期到期解决办法