从LDAP目录上下文对象中查找BASE DN

时间:2011-10-15 09:47:44

标签: java ldap ldap-query


我有LDAP的目录上下文,但我需要从中找出BASE DN 目录上下文对象。 我有以下代码来获取目录上下文对象,

// Configure our directory context environment.
Hashtable env = new Hashtable();
env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
env.put(Context.PROVIDER_URL, "ldap://test.mycomp.com:389");
env.put(Context.SECURITY_AUTHENTICATION, "Simple");
env.put(Context.SECURITY_PRINCIPAL,"uid=test.gen,OU=Generics,O=test.mycomp.com");
env.put(Context.SECURITY_CREDENTIALS, "test123");
DirContext dirContext = new InitialDirContext(env);
System.out.println("loaded dirContext");

我有以下代码来获取基本DN, 我一直在返回基本DN名称,但我想让我的过滤器优化,而不是放置2个循环来获得基本DN,

    SearchControls constraints = new SearchControls();
    constraints.setSearchScope(SearchControls.OBJECT_SCOPE);
    NamingEnumeration results = dirContext.search("",
            "(&(objectClass=organization)(objectClass=top))", constraints);

        // Fail if no entries found
    if (results == null || !results.hasMore()) {
        System.out.println("No result found");
        return;
    }

    while(results.hasMoreElements()){
        Object res = results.next();
        SearchResult serResult = (SearchResult) res;
        Attributes atts = serResult.getAttributes();
        System.out.println(atts.toString());
        Attribute baseAttr = atts.get("namingContexts");
        NamingEnumeration  ids = baseAttr.getAll();
        while(ids.hasMoreElements()){
            Object obj = ids.next();
            System.out.println(obj.toString());
        }
    }

请帮我优化我的过滤器。

2 个答案:

答案 0 :(得分:1)

您不需要搜索。只需从InitialContext获取namingContexts属性。

Attributes atttrs = context.getAttributes("", new String[]{"namingContexts"});

答案 1 :(得分:0)

LDAP兼容的目录服务器应在查询根DSE时提供有关namingContexts的信息。有关根DSE的详细信息,请参阅“LDAP: The root DSE”。 UnboundID LDAP SDK提供了一个封装根DSE的类和一个检索它的便捷方法。