我需要创建一个网页,根据现有的活动目录对用户进行身份验证。该域实际上是一种云计算配置,其中堆栈上有域控制器和多个其他服务器。
我理解可以使用System.DirectoryServices命名空间中的对象。但是,我似乎无法通过LDAP://domain.com将代码路径到活动目录 地址。似乎没有任何沟通。我怀疑有一些必要的初始配置或阻止通信的安全措施。
我正在使用MSDN上的这个示例:http://msdn.microsoft.com/en-us/library/ms180890(v=vs.80).aspx。
我收到一条错误消息,指出服务器无法运行。
答案 0 :(得分:2)
看一下这个链接(用web.archive.org替换旧链接):
http://www.codeproject.com/KB/system/everythingInAD.aspx#35
这是获取默认条目的方法:
try
{
System.DirectoryServices.DirectoryEntry AdRootDSE = new System.DirectoryServices.DirectoryEntry("LDAP://rootDSE");
string rootdse = System.Convert.ToString(AdRootDSE.Properties["defaultNamingContext"].Value);
if (!rootdse.StartsWith("LDAP://", StringComparison.OrdinalIgnoreCase) && !rootdse.StartsWith("LDAPS://", StringComparison.OrdinalIgnoreCase))
{
rootdse = "LDAP://" + rootdse;
}
return rootdse;
}
catch (Exception ex)
{
}
答案 1 :(得分:0)
LDAP://domain
服务器加入所述域时可以使用;在给定正确的DNS配置的情况下,它应该能够解析域控制器。
否则,如果您拥有域控制器的fqdn或ip地址,则可以使用
LDAP://fqdn.of.domaincontroller /* or */ LDAP://100.10.100.10
执行此操作意味着您已绑定到该DC,因此如果该计算机出现故障或被删除,您将无法进行身份验证。
答案 2 :(得分:0)
已经有一段时间了,但我认为我完全可以解决这个问题。
我针对这个宏伟的free to test LDAP server
进行了测试var path = "LDAP://ldap.forumsys.com:389/dc=example,dc=com";
var user = $@"uid={username},dc=example,dc=com";
var pass = "password";
var directoryEntry = new DirectoryEntry(path, user, pass, AuthenticationTypes.None);
var searcher = new DirectorySearcher(directoryEntry);
searcher.PropertiesToLoad.Add("*");
var searchResult = searcher.FindOne();
但是,我不完全了解所有这些行的用途,并且寻找解决方案时,我发现了一些建议。
在路径上,“ LDAP://”字符串应位于mayus块上。
在用户中,有时您需要使用“ cn = username-admin”来验证管理员,请确保还将“身份验证”类型设置为ServerBind。