регулярное выражение для разбора LDAP dn - PullRequest
4 голосов
/ 19 сентября 2008

У меня есть следующая строка:

cn=abcd,cn=groups,dc=domain,dc=com

Можно ли использовать регулярное выражение для извлечения строки после первого cn= и до первого ,? В приведенном выше примере ответ должен быть abcd.

Ответы [ 5 ]

12 голосов
/ 19 сентября 2008
 /cn=([^,]+),/ 

большинство языков извлекают совпадение как $ 1 или совпадения [1]

Если по какой-то причине вы не можете пользоваться подписками,

$x =~ s/^cn=//
$x =~ s/,.*$//

Это способ сделать это в 2 шага.

Если вы разбираете его из журнала с помощью sed

sed -n -r '/cn=/s/^cn=([^,]+),.*$/\1/p'    < logfile > dumpfile 

даст вам то, что вы хотите. (Дополнительные команды добавлены только для печати совпадающих строк)

6 голосов
/ 19 сентября 2008
/^cn=([^,]+),/
0 голосов
/ 20 июля 2012

Я должен был решить это на PHP.

Поскольку строка LDAP иногда может быть длинной и иметь много атрибутов, я подумал о том, как использовать ее в проекте.

Я хотел использовать:

CN=username,OU=UNITNAME,OU=Region,OU=Country,DC=subdomain,DC=domain,DC=com

И превратить это в:

array (
    [CN] => array( username )
    [OU] => array( UNITNAME, Region, Country )
    [DC] => array ( subdomain, domain, com )
)

Вот как я построил свой метод.

/**
 * Read a LDAP DN, and return what is needed
 *
 * Takes care of the character escape and unescape
 *
 * Using:
 * CN=username,OU=UNITNAME,OU=Region,OU=Country,DC=subdomain,DC=domain,DC=com
 *
 * Would normally return:
 * Array (
 *     [count] => 9
 *     [0] => CN=username
 *     [1] => OU=UNITNAME
 *     [2] => OU=Region
 *     [5] => OU=Country
 *     [6] => DC=subdomain
 *     [7] => DC=domain
 *     [8] => DC=com
 * )
 *
 * Returns instead a manageable array:
 * array (
 *     [CN] => array( username )
 *     [OU] => array( UNITNAME, Region, Country )
 *     [DC] => array ( subdomain, domain, com )
 * )
 *
 *
 * @author gabriel at hrz dot uni-marburg dot de 05-Aug-2003 02:27 (part of the character replacement)
 * @author Renoir Boulanger
 * 
 * @param  string $dn          The DN
 * @return array
 */
function parseLdapDn($dn)
{
    $parsr=ldap_explode_dn($dn, 0);
    //$parsr[] = 'EE=Sôme Krazï string';
    //$parsr[] = 'AndBogusOne';
    $out = array();
    foreach($parsr as $key=>$value){
        if(FALSE !== strstr($value, '=')){
            list($prefix,$data) = explode("=",$value);
            $data=preg_replace("/\\\([0-9A-Fa-f]{2})/e", "''.chr(hexdec('\\1')).''", $data);
            if(isset($current_prefix) && $prefix == $current_prefix){
                $out[$prefix][] = $data;
            } else {
                $current_prefix = $prefix;
                $out[$prefix][] = $data;
            }
        }
    }
    return $out;
}
0 голосов
/ 19 сентября 2008

Кроме того, ищите готовый парсер LDAP.

0 голосов
/ 19 сентября 2008

Да, используя синтаксис perl / java cn=([^,]*),. Затем вы получите 1-ю группу.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...