Besoin d'une méthode simple pour stocker les données de style livre d'adresses et les informations réseau aux côtés de données structurées? LDAP, une technologie datant de 1993, fournit une solution. Tout en manquant du facteur "cool" des nouvelles technologies comme Node.js et Go, ses capacités restent très pertinentes.
Concepts clés:
Comprendre LDAP:
LDAP, ou protocole d'accès au répertoire léger, est originaire de l'Université du Michigan vers 1993, grâce aux efforts de Tim Howes, Steve Kille, Colin Robbins et Wengyik Yeong. Il s'agit essentiellement d'une version conviviale d'Internet de l'ancien protocole X.500 (des années 1980), conçu à l'origine par l'International Telecommunications Union (UIT) pour la gestion des répertoires téléphoniques.
Bien que "LDAP" se réfère techniquement au protocole, il est souvent utilisé pour décrire les composants du client et du serveur. Considérez-le comme le SQL des serveurs d'annuaire - la langue pour interagir avec les serveurs compatibles LDAP.
Les serveurs LDAP populaires incluent Active Directory de Microsoft (intégré à Windows depuis Windows 2000) et l'OpenSource OpenLDAP, que nous utiliserons dans cette série de didacticiels. La flexibilité d'OpenLDAP permet un schéma et un stockage de données diverses.
Cette première partie couvre:
Terminologie essentielle:
Avant de continuer, clarifions certains termes clés:
LDAP Term | Description |
---|---|
dn | Distinguished Name: A record's unique identifier, similar to a primary key in relational databases. |
Directory Schema | Defines the structure and constraints of the directory information. |
entry | A record containing attributes that store data. |
attribute | Similar to an associative array element or database column; specifies the data type, sorting rules, case-sensitivity, and other criteria. |
cn | Common Name (e.g., "John Smith") |
sn | Surname (e.g., "Smith") |
Pour une compréhension plus approfondie, consultez les guides LDAP d'O'Reilly ou l'entrée Wikipedia sur LDAP.
Configuration d'un serveur LDAP:
L'installation et la configuration d'OpenDap peuvent être quelque peu complexes. Ces étapes, optimisées pour les serveurs basées à Debian, visent la clarté et la concision:
Installez le serveur de base et les utilitaires:
sudo apt-get install slapd ldap-utils
Configurez le serveur:
dpkg-reconfigure slapd
Répondez aux invites comme suit:
homestead.localdomain
(ou votre domaine) Vérification:
Vérifiez l'installation en fonctionnant:
ldapsearch -x -b dc=homestead,dc=localdomain
Si vous rencontrez des erreurs, assurez-vous que OpenLDAP est en cours d'exécution:
sudo netstat -tlnp | grep slapd
Vous devriez voir la sortie indiquant que SLAPD écoute sur le port 389.
remplissant la base de données:
Créer users.ldif
avec le contenu suivant:
dn: cn=Sheldon Cooper,ou=People,dc=homestead,dc=localdomain cn: Sheldon Cooper objectClass: person objectClass: inetOrgPerson sn: Cooper dn: cn=Leonard Hofstadter,ou=People,dc=homestead,dc=localdomain cn: Leonard Hofstadter objectClass: person objectClass: inetOrgPerson sn: Hofstadter dn: cn=Howard Wolowitz,ou=People,dc=homestead,dc=localdomain cn: Howard Wolowitz objectClass: person objectClass: inetOrgPerson sn: Wolowitz dn: cn=Rajesh Koothrappali,ou=People,dc=homestead,dc=localdomain cn: Rajesh Koothrappali objectClass: person objectClass: inetOrgPerson sn: Koothrappali
Chargez les données:
ldapadd -x -W -D "cn=admin,dc=homestead,dc=localdomain" -f users.ldif
(vous serez invité à le mot de passe administrateur.)
Vérifiez les enregistrements en utilisant:
ldapsearch -x -b "dc=homestead,dc=localdomain" -s sub "objectclass=*"
(L'interaction PHP, la connexion au serveur, la recherche, la mise à jour et la suppression suivront dans les sections suivantes, en raison de limitations de longueur.)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!