vml*_*l19 20 c# active-directory
DirectoryEntry oDE = new DirectoryEntry("LDAP://DC=Test1,DC=Test2,DC=gov,DC=lk");
using (DirectorySearcher ds = new DirectorySearcher(oDE))
{
ds.PropertiesToLoad.Add("name");
ds.PropertiesToLoad.Add("userPrincipalName");
ds.Filter = "(&(objectClass=user))";
SearchResultCollection results = ds.FindAll();
foreach (SearchResult result in results)
{
Console.WriteLine("{0} - {1}",
result.Properties["name"][0].ToString(),
result.Properties["userPrincipalName"][0].ToString());
}
}
Run Code Online (Sandbox Code Playgroud)
在SearchResultCollection results = ds.FindAll();
行我得到一个异常:
从服务器返回了推荐
为什么我会得到那个例外,这是什么意思?
And*_*bel 11
AD服务器在没有自己请求的信息时发送引用,但知道另一台服务器具有该信息.它通常出现在信任环境中,其中DC可以引用受信任域中的DC.
在您的情况下,您只是指定一个域,依赖于自动查找要使用的域控制器.我认为您应该尝试找出用于查询的域控制器,并查看该控制器是否真的包含所请求的信息.
如果您提供有关AD设置的更多信息,包括任何信任/子域,全局编录和域控制器的DNS资源记录,则可以更轻松地为您提供帮助.
这是问题的答案。原因是我的 LDAP 字符串错误。
try
{
string adServer = ConfigurationManager.AppSettings["Server"];
string adDomain = ConfigurationManager.AppSettings["Domain"];
string adUsername = ConfigurationManager.AppSettings["AdiminUsername"];
string password = ConfigurationManager.AppSettings["Password"];
string[] dc = adDomain.Split('.');
string dcAdDomain = string.Empty;
foreach (string item in dc)
{
if (dc[dc.Length - 1].Equals(item))
dcAdDomain = dcAdDomain + "DC=" + item;
else
dcAdDomain = dcAdDomain + "DC=" + item + ",";
}
DirectoryEntry de = new DirectoryEntry("LDAP://" + adServer + "/CN=Users," + dcAdDomain, adUsername, password);
DirectorySearcher ds = new DirectorySearcher(de);
ds.SearchScope = SearchScope.Subtree;
ds.Filter = "(&(objectClass=User)(sAMAccountName=" + username + "))";
if (ds.FindOne() != null)
return true;
}
catch (Exception ex)
{
ExLog(ex);
}
return false;
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
146825 次 |
最近记录: |