Извлечение многозначного атрибута из LDAP groupOfUniqueNames

Я пытаюсь прочитать всех участников, принадлежащих к группе, определенной в LDAP как groupOfUniqueNames.

String url = "ldap://blah.blah.address:389/dc=foo,dc=bar";
Hashtable<String, String> env = new Hashtable<String, String>();
env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
env.put(Context.PROVIDER_URL, url);

DirContext ctx = new InitialDirContext(env);
String[] attrIDs = {"uniqueMember"};
SearchControls cons = new SearchControls();

Attributes answer = ctx.getAttributes("cn=testgroup", attrIDs);

NamingEnumeration e = answer.getAll();
while (e.hasMore()) {
    BasicAttribute attr = (BasicAttribute) e.next();
    System.out.println(attr.getID() + ": " + attr.get());
}

Однако этот код печатает

uniqueMember:

как будто он не читал все значения уникального члена.

Используя Apache Directory Studio, я вижу, что этот атрибут имеет 3 значения (одно из которых пустое). Как я могу получить доступ ко всем из них?

Если это имеет значение, я использую OpenLDAP.


person Kylo    schedule 31.05.2011    source источник
comment
Похоже, LDAP вернул только пустое значение. Я не вижу ничего плохого в вашем коде, если только не проглатывается исключение. Есть ли какой-либо контроль доступа к этому члену? Вы используете анонимное соединение с любыми минимальными привилегиями, определенными для этого в slapd.conf.   -  person user207421    schedule 01.06.2011
comment
Нет, это определенно не проблема авторизации. Мне удалось решить эту проблему с помощью JLDAP.   -  person Kylo    schedule 01.06.2011
comment
Здравствуйте, у меня такая же проблема при попытке получить всех членов группы (члены — это многозначное поле в записи группы). Он вернет только первого члена. Это ошибка в OpenLDAP? Java JNDI? Я бы хотел придерживаться JNDI и по возможности избегать JLDAP. Спасибо за любые обходные пути/идеи.   -  person icordoba    schedule 07.11.2014


Ответы (1)


Мне удалось решить эту проблему с помощью JLDAP

LDAPConnection conn = new LDAPConnection();
conn.connect("blah.blah.address", 389);

String[] attrIDs = {"uniqueMember"};
LDAPSearchResults search = conn.search("dc=foo,dc=bar",
                                       LDAPConnection.SCOPE_ONE,
                                       "cn=testgroup", attrIDs, false);

while(search.hasMore()) {
    LDAPEntry entry = search.next();
    for (String string : entry.getAttribute("uniqueMember").getStringValueArray()) {
        System.out.println(string);
    }
} 
person Kylo    schedule 01.06.2011