从C#访问AD时"从服务器返回引用"异常

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();行我得到一个异常:

从服务器返回了推荐

为什么我会得到那个例外,这是什么意思?

Fre*_*red 19

可能你提供的路径不正确.检查一下.

我会推荐文章Howto :(几乎)通过C#在Active Directory中的一切,这在过去真正帮助我处理AD.


And*_*bel 11

AD服务器在没有自己请求的信息时发送引用,但知道另一台服务器具有该信息.它通常出现在信任环境中,其中DC可以引用受信任域中的DC.

在您的情况下,您只是指定一个域,依赖于自动查找要使用的域控制器.我认为您应该尝试找出用于查询的域控制器,并查看该控制器是否真的包含所请求的信息.

如果您提供有关AD设置的更多信息,包括任何信任/子域,全局编录和域控制器的DNS资源记录,则可以更轻松地为您提供帮助.


vml*_*l19 5

这是问题的答案。原因是我的 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)

  • -1 因为没有说明是什么解决了问题。 (22认同)
  • LDAP 字符串可能不够直观。在我们的例子中,我们有一个像 LDAP://DC=primary,DC=secondary,DC=com 的方法,它在大多数情况下都有效。但是当尝试以完全信任的方式连接到其子域时,字符串必须更改为:LDAP://MyDomainController1.primary.secondary.com (5认同)