LDAP это Lightweight Directory Access Protocol - протокол, используемый
для доступа к "Directory Servers". Directory это особый вид базы данных,
которая содержит информацию как древовидную структуру.
Концепция аналогична структуре директорий жёсткого диска,
но в данном контексте root/корневая директория это "The world/Земной шар",
а первый уровень поддиректорий это "countries/страны". Ещё ниже идут
уровни структуры директорий, содержащие вхождения для companies/компаний,
organisations/организаций или мест, а ещё ниже находятся вхождения
директорий для people/людей и, возможно, оборудования или документов.
Чтобы обратиться к файлу в поддиректории на жёстком диске, вы вводите что-нибудь вроде
/usr/local/myapp/docs
Слэш отделяет каждое подразделение ссылки, а последовательность читается
слева направо.
Эквивалентом для полной квалифицированной ссылки на файл в LDAP является "distinguished
name/различительное имя", называемое просто "dn". Примером dn может быть:
cn=John Smith,ou=Accounts,o=My Company,c=US
Запятая работает как слэш, а последовательность читается справа налево.
Вы можете прочитать это dn как ...
country = US
organization = My Company
organizationalUnit = Accounts
commonName = John Smith
Точно так же, поскольку нет твёрдых правил организации структуры
директорий на жёстком диске, directory server manager (менеждер сервера директорий) может настроить любую структуру,
необходимую для осуществления поставленных задач. Однако есть некоторые соглашения, которые при этом используются: вы не можете записать код для
доступа к серверу директорий, если не знаете его структуру, хотя можете использовать БД без знания того, что доступно.
Вам нужно получить и скомпилировать клиентские библиотеки LDAP из пакета ldap-3.3 University of Michigan
или Netscape Directory SDK 3.0. Вам нужно также перекомпилировать PHP с включённой поддержкой LDAP, прежде чем вызовы PHP к LDAP заработают.
Прежде чем начать использование вызовов LDAP, вам необходимо знать:
Имя или адрес сервера директорий, который вы будете использовать
"base dn" сервера (часть world-директории, которая содержится на этом сервере, которая может быть "o=My
Company,c=US")
Нужен ли вам пароль для доступа к этому серверу (многие серверы
предоставляют доступ для чтения для "anonymous bind", но требуют пароля для других действий)
Типичная последовательность вызова LDAP в вашем приложении будет соответствовать такому патэрну:
ldap_connect() // установить соединение
с сервером
|
ldap_bind() // anonymous/анонимный
или аутентифицированный "login"
|
сделать что-нибудь типа поиска или обновления директории
и вывести результаты
|
ldap_close() // "logout"