(PHP 7 >= 7.2.0)
ldap_exop — Выполнить расширенную операцию
$link
, string $reqoid
[, string $reqdata
= NULL
[, array $serverctrls
= NULL
[, string &$retdata
[, string &$retoid
]]]] ) : mixed
Выполняет расширенную операцию для заданного link
с OID
операции reqoid
и данными
reqdata
.
link
Идентификатор соединения LDAP, полученный из ldap_connect().
reqoid
Идентификатор расширенной операции OID. Можно использовать одну из констант LDAP_EXOP_START_TLS
, LDAP_EXOP_MODIFY_PASSWD
, LDAP_EXOP_REFRESH
, LDAP_EXOP_WHO_AM_I
, LDAP_EXOP_TURN
или строку с OID необходимой операции.
reqdata
Данные для запроса расширенной операции. Может быть NULL
для операций типа
LDAP_EXOP_WHO_AM_I
. Может потребоваться закодировать BER.
serverctrls
Массив управляющих констант LDAP для посылки в запросе.
retdata
Если задано, то будет заполнено данными, полученными в результате выполнения операции. Если не задано, то для получения данных можно использовать ldap_parse_exop для полученного объекта.
retoid
Если задано, то будет заполнено OID ответа. Обычно совпадает с OID запроса.
Если используется с retdata
, то возвращает TRUE
или FALSE
.
Если используется без retdata
, то возвращает идентификатор ресурса или FALSE
.
Версия | Описание |
---|---|
7.3 |
Добавлена поддержка serverctrls
|
Пример #1 Расширенная операция Whoami
<?php
$ds = ldap_connect("localhost"); // предположим, что сервер LDAP запущен локально
if ($ds) {
// Привязываемся к нужному DN
$bind = ldap_bind($ds, "cn=root, o=My Company, c=US", "secret");
if (!$bind) {
echo "Невозможно осуществить привязку LDAP";
exit;
}
// Вызываем WHOAMI EXOP
$r = ldap_exop($ds, LDAP_EXOP_WHO_AM_I);
// Разбираем полученный ответ
ldap_parse_exop($ds, $r, $retdata);
// Вывод: string(31) "dn:cn=root, o=My Company, c=US"
var_dump($retdata);
// То же самое, но с параметром $retdata
$success = ldap_exop($ds, LDAP_EXOP_WHO_AM_I, NULL, NULL, $retdata, $retoid);
if ($success) {
var_dump($retdata);
}
ldap_close($ds);
} else {
echo "Невозможно соединиться с сервером LDAP";
}
?>