1

このコード スニペットを使用して、ユーザーを LDAP に追加します

**public DirContext getLDAPDirContext() throws NamingException {
    final Hashtable envValues = new Hashtable();
    // Assign the JNDI environment values in Map
    envValues.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
    envValues.put(Context.PROVIDER_URL, url);
    envValues.put(Context.SECURITY_PRINCIPAL,dn); // specify the username
    envValues.put(Context.SECURITY_CREDENTIALS,password);           // specify the password
    return new InitialDirContext(envValues);
}
public static void main(String arg[]) throws NamingException {
    LdapNew ldapNew = new LdapNew();
    String groupDN ="ou=user,dc=ldap,dc=***,dc=***";
    BasicAttributes myAttrs = new BasicAttributes(true);  //Basic Attributes
    myAttrs.put("uid","chamils");
    myAttrs.put("objectClass","top");
    myAttrs.put("objectClass","dcObject");
    myAttrs.put("objectClass","organization");
    myAttrs.put("objectClass", "inetOrgPerson");
    myAttrs.put("cn","FNAME LNAME");
    myAttrs.put("displayname", "FNAME LNAMEE");
    myAttrs.put("givenname","Chamilseeee");
    myAttrs.put("sn","Thanthrimudaliged");
    myAttrs.put("mail","*******");
    DirContext ctx = ldapNew.getLDAPDirContext();
    ctx.bind("uid=chamils,ou=user,dc=ldap,dc=****,dc=***",myAttrs);
}**

しかし、それは与えます

スレッド「メイン」での例外 javax.naming.directory.InvalidAttributeIdentifierException: [LDAP: エラー コード 17 - javaSerializedData: 属性タイプが定義されていません]; 残りの名前 'uid=chamils,ou=user,dc=ldap,dc= ,dc=' com.sun.jndi.ldap.LdapCtx.mapErrorCode(LdapCtx.java:3110) で com.sun.jndi.ldap.LdapCtx.processReturnCode(LdapCtx.java:2987) で com.sun.jndi.ldap.LdapCtx. com.sun.jndi.ldap.LdapCtx.c_bind(LdapCtx.java:397) の processReturnCode(LdapCtx.java:2794) com.sun.jndi.ldap.LdapCtx.c_bind(LdapCtx.java:354) の com.sun .jndi.toolkit.ctx.ComponentContext.p_bind(ComponentContext.java:596) at com.sun.jndi.toolkit.ctx.PartialCompositeContext.bind(PartialCompositeContext.java:183) at com.sun.jndi.toolkit.ctx.PartialCompositeContext .bind(PartialCompositeContext.java:173) で javax.naming.InitialContext.bind(InitialContext.java:400) で LdapNew.main(LdapNew.java:49) で sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) で sun. Reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) で sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) で java.lang.reflect.Method.invoke(Method.java:597) で com.intellij.rt.execution.application.AppMain.main で(AppMain.java:120)

何故ですか。

4

1 に答える 1

1

include schema/java.schemaOpenLDAP 構成に追加する必要があります。

于 2012-08-15T11:02:54.637 に答える