首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >从C#访问AD时出现“从服务器返回参考”异常

从C#访问AD时出现“从服务器返回参考”异常
EN

Stack Overflow用户
提问于 2011-08-05 17:27:21
回答 8查看 165.7K关注 0票数 22
代码语言:javascript
复制
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());
    }
}

SearchResultCollection results = ds.FindAll();行上,我得到了一个异常:

从服务器返回了一个引用

为什么我会得到这个异常,它意味着什么?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2011-09-09 10:08:25

这是question.Reason的答案,原因是我的LDAP字符串错误。

代码语言:javascript
复制
    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;
票数 5
EN

Stack Overflow用户

发布于 2011-08-05 17:38:40

可能您提供的路径不正确。看看这个。

我会重新评论Howto: (Almost) Everything In Active Directory via C#这篇文章,这篇文章在过去对我处理AD真的很有帮助。

票数 19
EN

Stack Overflow用户

发布于 2011-08-08 00:53:31

当AD服务器本身没有请求的信息,但知道另一台服务器有该信息时,就会发送推荐。它通常出现在信任环境中,其中DC可以引用受信任域中的DC。

在您的示例中,您仅指定域,这依赖于自动查找要使用的域控制器。我认为您应该尝试找出查询所使用的域控制器,并查看该域控制器是否真的包含所请求的信息。

如果您提供有关AD设置的更多信息,包括域控制器的任何信任/子域、全局目录和DNS资源记录,将更容易帮助您。

票数 12
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6954170

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档