LDAP JNDI子树搜索



我在搜索LDAP时遇到问题。如果我使用以下代码,我可以使用以下代码获得级别2。但我想得到4级对象。谢谢你的帮助。

当前搜索库:ou=HQ2-BR,过滤器:"(ou=*)";

谨致问候,Man Pak Hong,Davemanpakhong@hotmail.commanpakhong@gmail.com

LDAP结构

  • o=com,dc=rabbitforever#(0级)
    • ou=HQ2-BR//参考其他广告#(1级)
      • ou=TSB//#(级别2)
      • ou=BM1//#(级别2)
      • ou=IIC//#(2级)
        • ou=人员//#(级别3)
          • uid=IICCIO//#(级别4)
          • uid=IICSIO1//#(级别4)

代码:

public void loopLDAP() {
    String adminName = "uid=writer,ou=People,o=com,dc=rabbitforever";
    String adminPassword = "password";
    Properties env = new Properties();
    env.put(Context.INITIAL_CONTEXT_FACTORY,
            "com.sun.jndi.ldap.LdapCtxFactory");
    //env.put(Context.PROVIDER_URL,
    //        "ldap://192.168.1.127:389/dc=rabbitforever,dc=com");
    env.put(Context.PROVIDER_URL,
            "ldap://10.10.176.156:389/o=com,dc=rabbitforever");
    //env.put(Context.SECURITY_AUTHENTICATION, "none");
    env.put(Context.SECURITY_PRINCIPAL, adminName);
    env.put(Context.SECURITY_CREDENTIALS, adminPassword);
    env.put(Context.SECURITY_AUTHENTICATION, "simple");
    env.put(Context.REFERRAL, "follow");
    try {
        LdapContext ctx = new InitialLdapContext(env, null);
        ctx.setRequestControls(null);
        String filter = "(ou=*)";
        NamingEnumeration<?> namingEnum = ctx.search("ou=HQ2-BR", filter,
                getSimpleSearchControls());
        while (namingEnum.hasMore()) {
            SearchResult result = (SearchResult) namingEnum.next();
            Attributes attrs = result.getAttributes();
            String cn = "";
            String sn = "";
            String description = "";
            String uid = "";
            if (null != attrs.get(cn)) {
                cn = attrs.get("cn").toString();
            }
            if (null != attrs.get("sn")) {
                sn = attrs.get("sn").toString();
            }
            if (null != attrs.get("description")) {
                description = attrs.get("description").toString();
            }
            if (null != attrs.get("uid")) {
                uid = attrs.get("uid").toString();
            }
            System.out.println(cn + " | " + sn + " | " + description
                    + " | " + uid);
        }
    } catch (Exception ex) {
        ex.printStackTrace();
    }
} // end loopLDAP()

您可能需要用SearchControls.SUBTREE_SCOPE构造SearchControls对象,并将其传递给ctx.search方法。请参阅另一个答案中的示例。

最新更新