我使用以下代码从LDAP列出用户:
Hashtable<String, String> env = new Hashtable<String, String>();
env.put(Context.INITIAL_CONTEXT_FACTORY, CONTEXT);
env.put(Context.PROVIDER_URL, HOST);
env.put(Context.SECURITY_PRINCIPAL,USER);
env.put(Context.SECURITY_CREDENTIALS,PASSWORD);
DirContext ctx = new InitialDirContext(env);
SearchControls sc = new SearchControls();
sc.setSearchScope(SearchControls.SUBTREE_SCOPE);
NamingEnumeration items = ctx.search(BASE, filter, sc);
while (items != null && items.hasMore()) {
SearchResult sr = (SearchResult)items.next();
System.out.println("SR : " + sr) ;
}
现在我得到了输出;
SR : cn=smith: null:null:{objectclass=objectClass: person, sn=sn: smith, cn=cn: smith}
SR : cn=king: null:null:{objectclass=objectClass: person, sn=sn: king, cn=cn: king}
如何从SearchControls获取输出,如:
sn = smith | cn = smith
sn = king | cn = king
答案 0 :(得分:3)
如果您的sysout中的简单更改不足以满足要求吗?
System.out.println("SR : "
+ sr.getAttributes().get("sn")
+ " | "
+ sr.getAttributes().get("cn")
) ;
或者,我在这里读错了吗?
答案 1 :(得分:0)
您可以尝试将SR字符串与一对正则表达式匹配,以获得sn
和cn
的值:
sn=sn: ([^,]),
cn=cn: ([^,]),