我正在使用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


当controle出现在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


搜索了很多,但无法解决。有人请帮我。

最佳答案

异常指示专有名称中的语法无效。 DN语法(尤其是有关特殊字符编码的语法)非常复杂,因此您通常应避免使用字符串串联构造可分辨的名称(如果您正在这样做的话)。

考虑使用LdapNameBuilder来构建专有名称。

关于java - Spring ldapTemplate的查找方法期间的问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27902956/

10-10 23:56