/** * * ModifyRDN .java * Sample code to demostrate how ModifyRDN/ModifyDN works. * */
import javax.naming.; import javax.naming.directory.;
import java.util.Hashtable;
public class ModifyRDN { public static void main(String[] args) { Hashtable env = new Hashtable(); env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
env.put(Context.PROVIDER_URL, "ldap://myLdapServer:389/dc=myDomain,dc=com");
env.put(Context.SECURITY_AUTHENTICATION, "simple");
env.put(Context.SECURITY_PRINCIPAL, "cn=directory manager");
env.put(Context.SECURITY_CREDENTIALS, "password");
/*
Whether the old RDN attribute values are to be retained
as attributes of the entry, or deleted from the entry
*/
env.put("java.naming.ldap.deleteRDN", "true"); // default is 'true'
try {
/* Create the initial context */
DirContext ctx = new InitialDirContext(env);
ctx.rename("cn=John Smith,ou=Sales,ou=People",
"cn=John Cougar Smith,ou=Sales,ou=People");
/* Close the context when it's done */
ctx.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
/////////////////////// My error list is as follows javax.naming.NameNotFoundException: [LDAP: error code 32 - No Such Object]; remaining name 'cn=name1 name2,ou=mycompany' at com.sun.jndi.ldap.LdapCtx.mapErrorCode(LdapCtx.java:3025) at com.sun.jndi.ldap.LdapCtx.processReturnCode(LdapCtx.java:2946) at com.sun.jndi.ldap.LdapCtx.processReturnCode(LdapCtx.java:2752) at com.sun.jndi.ldap.LdapCtx.c_rename(LdapCtx.java:700) at com.sun.jndi.toolkit.ctx.ComponentContext.p_rename(ComponentContext.java:708) at com.sun.jndi.toolkit.ctx.PartialCompositeContext.rename(PartialCompositeContext.java:266) at com.sun.jndi.toolkit.ctx.PartialCompositeContext.rename(PartialCompositeContext.java:255) at javax.naming.InitialContext.rename(InitialContext.java:395) at ModifyRDN.main(ModifyRDN.java:22)