我做了一个LDAP目录搜索,得到了一些结果。我需要迭代这些结果并显示每个条目的Dn。
在我的测试环境中,我通过获取entryDN属性的值返回了Dn值。
在生产环境中,entryDN属性总是返回null。
在这两种环境中,当我返回Dn属性的值时,得到的结果都是null。
我真正需要做的是从任何环境中可靠地获取Dn。
有什么建议吗?
发布于 2015-10-06 01:24:31
要可靠地获取Dn,请使用SearchResult.getNameInNamespace()方法;
发布于 2019-07-10 01:12:57
基于user2135970的回答,将JNDI与Spring LDAP混合并不是很好,但它是可以做到的:
private String getDistinguishedName(String addtlFilter) throws NamingException {
String dn = null;
LdapContextSource contextSource = (LdapContextSource) ldapTemplate.getContextSource();
SearchControls ctrls = new SearchControls();
ctrls.setSearchScope(SearchControls.SUBTREE_SCOPE);
DirContext dc = null;
try {
dc = ldapTemplate.getContextSource().getContext(contextSource.getUserDn(), contextSource.getPassword());
final String filter = String.format("(&(%s)%s)", addtlFilter, searchFilter);
NamingEnumeration<SearchResult> results = dc.search(searchBase, filter, ctrls);
if (results.hasMore()) {
dn = results.next().getNameInNamespace();
}
} finally {
if (dc != null) {
dc.close();
}
}
return dn;
}https://stackoverflow.com/questions/32951844
复制相似问题