0
ich LdapTemplate in meinem Frühling application.While Hinzufügen von Datensätzen es Fehler LDAP: error code 65 - object class 'inetOrgPerson' requires attribute 'sn'
LDAP: Fehlercode 65 - Objektklasse 'inetOrgPerson' erfordert Attribut 'sn'
Mein Repository-Code ist
@Autowired
private LdapTemplate ldapTemplate;
@Autowired
private PasswordEncoder passwordEncoder;
public void setLdapTemplate(LdapTemplate ldapTemplate) {
this.ldapTemplate = ldapTemplate;
}
public void create(User user) {
Name dn = buildDn(user);
DirContextAdapter context = new DirContextAdapter(dn);
mapToContext(user, context);
ldapTemplate.bind(dn, context, null);
}
private LdapName buildDn(User user) {
return LdapNameBuilder
.newInstance()
.add("cn", user.getName())
.add("sn", user.getLname())
.add("uid", user.getUid())
.add("userPassword", passwordEncoder.encode(user.getPassword()))
.build();
}
private void mapToContext(User user, DirContextAdapter context) {
context.setAttributeValues("objectclass", new String[] { "top", "inetOrgPerson" });
context.setAttributeValue("uid", user.getName());
context.setAttributeValue("userPassword",
passwordEncoder.encode(user.getPassword()));
}
}
geben bin mit Ich ändere auch inetOrgPerson zu Person, organisationalPerson aber es wird nicht funktionieren.
Wo, wie ich ldif Datei von meinem Terminal
dn: ou=roles,dc=cofinding,dc=com
objectclass: top
objectclass: organizationalUnit
ou: roles
dn: ou=people,dc=cofinding,dc=com
objectclass: top
objectclass: organizationalUnit
ou: people
# Users
dn: uid=admin1,ou=people,dc=cofinding,dc=com
objectclass: top
objectclass: person
objectclass: organizationalPerson
objectclass: inetOrgPerson
cn: Prashant
sn:Thorat
uid: admin1
userPassword: admin1Pass
dn: uid=admin2,ou=people,dc=cofinding,dc=com
objectclass: top
objectclass: person
objectclass: organizationalPerson
objectclass: inetOrgPerson
cn: Aniket
sn:Patil
uid: admin2
userPassword: admin2Pass
dn: uid=user1,ou=people,dc=cofinding,dc=com
objectclass: top
objectclass: person
objectclass: organizationalPerson
objectclass: inetOrgPerson
cn: Gautam
sn:Kanawade
uid: user1
userPassword: user1Pass
# Roles
dn: cn=USER,ou=roles,dc=cofinding,dc=com
objectclass: top
objectclass: groupOfNames
cn: USER
member: uid=admin1,ou=people,dc=cofinding,dc=com
member: uid=admin2,ou=people,dc=cofinding,dc=com
member: uid=user2,ou=people,dc=cofinding,dc=com
dn: cn=ADMIN,ou=roles,dc=cofinding,dc=com
objectclass: top
objectclass: groupOfNames
cn: ADMIN
member: uid=admin1,ou=people,dc=cofinding,dc=com
member: uid=admin2,ou=people,dc=cofinding,dc=com