|
ldap_searchSuche im LDAP Baum Beschreibung
resource ldap_search
( resource
$Verbindungs-Kennung
, string $base_dn
, string $filter
[, array $merkmale
[, int $nur_werte
[, int $größenbegrenzung
[, int $zeitbegrenzung
[, int $deref
]]]]] )
Rückgabewert: eine Such-Ergebnis-Kennung im Erfolgsfall,
Die ldap_search Funktion führt die Suche für
einen gegebenen Filter im Verzeichnis mit der Reichweite von
LDAP_SCOPE_SUBTREE durch. Das ist äquivalent zu einer Suche im
ganzen Verzeichnis. Der optionale vierte Parameter kann benutzt werden, um die Rückgabewerte des Servers so einzuschränken, dass nur die tatsächlich benötigten Merkmale und ihre zugehörigen Werte in der Ergebnismenge enthalten sind. Dieses Vorgehen ist um einiges effizienter als die standardmäßige Vorgehensweise (diese liefert alle Merkmale und alle zugehörigen Werte). Aus diesem Grund ist die Angabe des vierten Parameters als gute Praxis zu empfehlen. Der vierte Parameter ist ein Standard PHP Array aus Strings der benötigten Merkmale, z.B. array("mail","sn","cn"). Beachten Sie, dass der "dn" immer zurückgeliefert wird, ohne Rücksicht darauf, welche Merkmalstypen angefragt wurden.
Beachten Sie weiterhin, dass manche Verzeichnis-Server so
konfiguriert sind, dass sie nicht mehr als eine vorbestimmte
Anzahl an Einträgen zurückliefern. Sollte dies der Fall sein,
zeigt Ihnen der Server an, dass nur eine Teilmenge des
Ergebnisses zurückgeliefert wurde. Diesen Hinweis erhalten Sie
auch, wenn Sie den sechsten Parameter
Der fünfte Parameter
Mit dem sechsten Parameter
Der siebte Parameter
Der achte Parameter
Der Suchfilter kann einfach oder kompliziert sein, wenn sie boolsche Operatoren in dem Format verwenden, wie in der LDAP Dokumentation beschrieben (siehe » Netscape Directory SDK für die vollständige Information über Filter). Das untenstehende Beispiel liefert die Organisationseinheit, den Familiennamen, den Vornamen und die Email-Addresse aller Personen in "Meine Firma" deren Familien- oder Vorname die Zeichenkette $person enhält. In diesem Beispiel wird ein boolscher Filter verwendet, um den Server zu veranlassen, nach Informationen in mehr als einem Merkmal zu suchen. Beispiel #1 LDAP Suche
// $ds gültige Verbindungs-Kennung für einen Verzeichnis-Server
Seit der Version 4.0.5 ist es außerdem möglich parallele Suchen
durchzuführen. Um dies zu verwirklichen benutzen Sie als erstes
Argument einen Array von Verbindungs-Kennungen, statt einer
einzelnen Verbindungs-Kennung. Falls Sie nicht den gleichen Basis
DN und den gleichen Filter für alle Suchen verwenden möchten,
können Sie ebenso einen Array von Basis DNs und/oder einen Array
von Filtern benutzen. Diese Arrays müssen die gleiche Größe wie
das Array der Verbindungs-Kennungen haben, da die ersten Einträge
der Arrays für eine Suche verwendet werden, die zweiten Einträge
für eine andere Suche und so weiter. Wenn Sie parallel suchen
erhalten Sie ein Array von Such-Ergebnis-Kennungen, außer im Fall
eines Fehlers, dann liefert der Eintrag zur entsprechenden Suche
|