Регулярное выражение для разбора LDAP dn
У меня есть следующая строка:
cn=abcd,cn=groups,dc=domain,dc=com
Можно ли использовать регулярное выражение для извлечения строки после первого cn=
и до первого ,
? В приведенном выше примере ответ должен быть abcd
,
5 ответов
/cn=([^,]+),/
большинство языков извлекает совпадение как $1 или совпадения [1]
Если вы не можете по какой-то причине пользоваться подписками,
$x =~ s/^cn=//
$x =~ s/,.*$//
Это способ сделать это в 2 этапа.
Если вы разбираете его из журнала с помощью sed
sed -n -r '/cn=/s/^cn=([^,]+),.*$/\1/p' < logfile > dumpfile
получите то, что вы хотите. (Добавлены дополнительные команды только для печати совпадающих строк)
Я должен был решить это на 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;
}
Да, используя синтаксис Perl/ Java cn=([^,]*),
, Затем вы получите 1-ую группу.