我正在使用Spring的ldapTemplate。在我的ldaputility.java中,我这样做:
public Object findUser(String username) {
System.out.println("inside find USer with username : "+username);
Object object=ldapTemplate.lookup("uid=xyz,cn=users,o=companyName",
new AttributesMapper<Object>()//GETTING ERROR AT THIS LINE
{
@Override
public User mapFromAttributes(Attributes attrs) throws NamingException {
User user = new User();
user.setFullName((String)attrs.get("cn").get());
user.setLastName((String)attrs.get("sn").get());
user.setPassword((String)attrs.get("password").get());
return user;
}
});
return object;
}
在我的ldif我做的是这样的事情:
dn: o=companyName
objectclass: domain
objectclass: top
dn: cn=users,o=companyName
objectclass: container
objectclass: top
cn: users
dn: cn=groups,o=companyName
objectclass: top
objectclass: container
cn: groups
dn: uid=xyz,cn=users,o=companyName
objectclass: top
objectclass: person
objectclass: organizationalPerson
objectclass: inetOrgPerson
uid: xyz
userpassword: xyz123
sn: xyz
givenName: xyz
cn: xyz abc
当ldapTemplate.lookup()出现控制时,我收到以下错误
org.springframework.ldap.InvalidNameException: uid=xyz,cn=users,o=companyName: [LDAP: error code 34 - Invalid DN Syntax];
nested exception is javax.naming.InvalidNameException: uid=xyz,cn=users,o=companyName: [LDAP: error code 34 - Invalid DN Syntax];
remaining name 'uid=xyz,cn=users,o=companyName
搜索了很多但无法解决此问题。有人请帮帮我。
答案 0 :(得分:2)
异常表示可分辨名称中的语法无效。 DN语法 - 特别是关于特殊字符的编码 - 非常复杂,因此您通常应该避免使用字符串连接构建专有名称(如果这就是您正在做的事情)。
考虑使用LdapNameBuilder来构建专有名称。