(PHP 4, PHP 5, PHP 7, PHP 8)
ldap_list — Одноуровневый поиск
$ldap
,$base
,$filter
,$attributes
= [],$attributes_only
= 0,$sizelimit
= -1,$timelimit
= -1,$deref
= LDAP_DEREF_NEVER
,$controls
= null
Выполняет поиск для указанного filter
в
директории в рамках LDAP_SCOPE_ONELEVEL
.
LDAP_SCOPE_ONELEVEL
означает, что поиск должен
возвратить только информацию, которая является следующим уровнем ниже
base
, заданного при вызове.
(Эквивалент вводу "ls" и получения списка файлов и папок
в текущем рабочем каталоге.)
Также можно выполнять параллельный поиск. В этом случае первым аргументом должен быть массив
экземпляров LDAP\Connection, а не один экземпляр.
Если поиск не должен использовать один и тот же базовый DN и фильтр, в качестве аргументов можно передать массив базовых DN и/или массив фильтров.
Количество элементов в массивах должно совпадать с количеством экземпляров LDAP\Connection,
поскольку первые записи массивов используются для одного поиска, вторые — для другого и так далее.
При параллельном поиске возвращается массив экземпляров LDAP\Result, за исключением возникновения ошибки, когда возвращается значение false
.
ldap
Экземпляр LDAP\Connection, который возвращает функция ldap_connect().
base
Базовое DN для каталога.
filter
attributes
Массив необходимых атрибутов, например, array("mail", "sn", "cn")
.
Обратите внимание, что "dn" возвращается всегда, независимо от того, какие
типы атрибутов требуются.
Использование этого параметра намного более эффективно чем действие по умолчанию (которое должно возвратить все атрибуты и их присвоенные значения). Поэтому использование этого параметра нужно считать хорошей практикой.
attributes_only
Должен быть равен 1, только если требуются типы атрибута. Если установлено 0, то, по умолчанию, выбираются и типы атрибутов и значения атрибута.
sizelimit
Позволяет ограничить количество выбранных записей. Установка этого параметра как 0 означает, что ограничение отсутствует.
Замечание:
Этот параметр НЕ может переопределять предустановку sizelimit на стороне сервера. Хотя его можно установить ниже.
Некоторые хосты серверов каталогов будут сконфигурированы так, чтобы возвратить не больше, чем предварительно установленное число записей. Если это произойдёт, то сервер укажет, что возвратил только частичный набор результатов. Это также происходит, если Вы используете этот параметр, чтобы ограничить количество выбранных записей.
timelimit
Устанавливает число секунд, ограничивающее процесс поиска. Установка этого параметра как 0 означает, что ограничение отсутствует.
Замечание:
Этот параметр НЕ может переопределять предустановку timelimit на стороне сервера. Хотя его можно установить ниже.
deref
Определяет, как псевдонимы должны быть обработаны во время поиска. Может быть одним из следующих:
LDAP_DEREF_NEVER
- (по умолчанию) псевдонимы никогда не разыменовываться.
LDAP_DEREF_SEARCHING
- псевдонимы должны быть разыменованы во время поиска,
но не при определении местоположения базового объекта поиска.
LDAP_DEREF_FINDING
- псевдонимы должны быть разыменованы при определении
местоположения базового объекта, но не во время поиска.
LDAP_DEREF_ALWAYS
- псевдонимы должны всегда разыменовываться всегда.
controls
Массив управляющих констант LDAP для отправки в запросе.
Возвращает экземпляр LDAP\Result, массив экземпляров LDAP\Result или false
в случае возникновения ошибки.
Версия | Описание |
---|---|
8.1.0 |
Параметр ldap теперь ожидает экземпляр LDAP\Connection;
ранее ожидался ресурс (resource) ldap link .
|
8.1.0 | Возвращает экземпляр LDAP\Result; ранее возвращался ресурс (resource). |
8.0.0 |
controls теперь допускает значение null; ранее значение по умолчанию было [] .
|
7.3.0 |
Добавлена поддержка параметра controls
|
Пример #1 Выводит список всех организационных единиц организации
<?php
// $ds допустимый экземпляр LDAP\Connection
$basedn = "o=My Company, c=US";
$justthese = array("ou");
$sr = ldap_list($ds, $basedn, "ou=*", $justthese);
$info = ldap_get_entries($ds, $sr);
for ($i=0; $i < $info["count"]; $i++) {
echo $info[$i]["ou"][0];
}
?>