0

そのため、LDAP 検索を機能させることができない理由を突き止めようとして、私は頭がおかしくなりました。

private String getDNFromLDAP(String strUID)
    {
        String strDN = "";

        //Create an LDAP Entry Object
        DirectoryEntry entry = new DirectoryEntry("LDAP://something.blah.com/cn=people,dc=blah,dc=com");
        entry.AuthenticationType = AuthenticationTypes.SecureSocketsLayer;
        entry.Username = "cn=myaccount,cn=special,dc=blah,dc=com";
        entry.Password = "supersecret";

        DirectorySearcher mySearcher = new DirectorySearcher(entry);
        mySearcher.SearchScope = SearchScope.Subtree;
        mySearcher.Filter = "(uid=" + strUID + ")";
        SearchResult result = mySearcher.FindOne();

        int nIndex = result.Path.LastIndexOf("/");
        strDN = result.Path.Substring((nIndex + 1)).ToString().TrimEnd();

        //Clean up objects
        entry.Close();
        entry.Dispose();
        mySearcher.Dispose();

        //returns the DN
        return strDN;
    }

検索しているオブジェクトが存在することはわかっていますが (ldapsearch で確認)、結果が空のままになります。ベース dn に問題があると思われますが、DirectorySearch がベース dn として使用しているものを確認する方法がわかりません。どんな助けでも大歓迎です。

4

1 に答える 1

0

searchroot プロパティを使用してルートを設定します。ルートは、コンストラクターで渡すエントリに設定されているため、エントリが見つからない可能性があります。

于 2013-06-20T17:26:29.757 に答える