【问题标题】:How to add new group using JNDI to ApacheDS?如何使用 JNDI 将新组添加到 ApacheDS?
【发布时间】:2012-08-07 14:58:56
【问题描述】:

我试过了

java.util.Hashtable;
import java.util.Properties;
import java.util.jar.Attributes;

import javax.naming.Context;
import javax.naming.NamingException;
import javax.naming.directory.Attribute;
import javax.naming.directory.BasicAttribute;
import javax.naming.directory.BasicAttributes;
import javax.naming.directory.DirContext;
import javax.naming.directory.InitialDirContext;

    public class Main{  


            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://localhost:10389");
                 env.put(Context.SECURITY_AUTHENTICATION, "simple");
                 env.put(Context.SECURITY_PRINCIPAL,"uid=admin,ou=system"); // specify the username
                 env.put(Context.SECURITY_CREDENTIALS,"secret");// specify the password
                // TODO code application logic here  

                          // entry's DN 
           String entryDN = "cn=myadmins,ou=groups,ou=system";  

            // entry's attributes  

            Attribute cn = new BasicAttribute("cn", "myadmins");  
            Attribute oc = new BasicAttribute("objectClass");  
            oc.add("top");  
            oc.add("groupOfUniqueNames");   
            DirContext ctx = null;  

            try {  
                // get a handle to an Initial DirContext  
                ctx = new InitialDirContext(env);  

                // build the entry  
                BasicAttributes entry = new BasicAttributes();  
                entry.put(cn);  

                entry.put(oc);  

                // Add the entry  

                ctx.createSubcontext(entryDN, entry);  
      //          System.out.println( "AddUser: added entry " + entryDN + ".");  

            } catch (NamingException e) {  
                System.err.println("AddUser: error adding entry." + e);  
            }  
         }  
    }  

我正在研究 DS 的示例默认架构。

但我明白了

Required attributes [uniqueMember(2.5.4.50)] not found within entry cn=myadmins,ou=groups,ou=system]; remaining name 'cn=myadmins,ou=groups,ou=system'

我查看了其他组条目,它具有 uniqueMember 属性值:

0.9.2342.19200300.100.1.1=admin,2.5.4.11=system

如何为我的新组指定 uniqueMember 属性的值,

我必须承认,包含点的数字对我来说有点复杂。

谢谢

【问题讨论】:

    标签: java ldap jndi apacheds


    【解决方案1】:

    uniqueMember 属性具有 DN 语法。这意味着必须将专有名称用作值,而不是相对专有名称(或专有名称的组成部分)。专有名称类似于文件系统上的完全限定路径名。

    uniqueMember 属性值视为指向作为组成员的专有名称的“指针”。

    更新:

    the number containing dotsOID。 LDAP 中的属性、控件和其他事物使用 OID,例如,像 cn 这样的属性有一个与之关联的 OID,用于在架构中唯一地标识它。

    【讨论】:

    • 我想我必须在定义新组时指定一个 uniqueMember。因此,我该如何指定它?指定 uniqueMember 时是否必须考虑一些参数?
    • uniqueMember 是管理员的可分辨名称,如果组名有任何指示。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-09-05
    • 1970-01-01
    • 2015-06-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多