| LDAP (Lightweight Directory Access Protocol) 是一种轻量的目录存取协议,提供客户从各个角落连接到目录服务器中。在 RFC 1777 及 RFC 1778 中对 LDAP 有较深入的描述,亦可参考 Netscape 站上有关 LDAP 方面的资料。 
在 LDAP 的协议之中,很像硬盘目录结构或倒过来的树状结构。LDAP 的根就是全世界,第一级是属于国别 (countries) 性质的层级,之后可能会有公司 (organization) 的层级,接着是部门 (organizationalUnit),再来为个人。而就像文件,每个人都会有所谓的显名 (distinguished name, 简称 dn),dn 可能像酱子 cn=John Smith,ou=Accounts,o=My Company,c=US。
 
<?php // 本例使用到 connect, bind, search, interpret search // result, close connection 等等 LDAP 的功能。 echo "<h3>LDAP 搜寻测试</h3>"; echo "连接中 ..."; $ds=ldap_connect("localhost");  // 先连上有效的 LDAP 服务器 echo "连上 ".$ds."<p>";
  if ($ds) {      echo "Binding ...";      $r=ldap_bind($ds);          // 匿名的 bind,为只读属性     echo "Bind 返回 ".$r."<p>";     echo "Searching for (sn=S*) ...";  // 找寻 S 开头的姓氏     $sr=ldap_search($ds,"o=My Company, c=US", "sn=S*");       echo "Search 返回 ".$sr."<p>";     echo "S 开头的姓氏有 ".ldap_count_entries($ds,$sr)." 个<p>";     echo "取回姓氏资料 ...<p>";     $info = ldap_get_entries($ds, $sr);     echo "资料返回 ".$info["count"]." 笔:<p>";     for ($i=0; $i<$info["count"]; $i++) {         echo "dn 为: ". $info[$i]["dn"] ."<br>";         echo "cn 为: ". $info[$i]["cn"][0] ."<br>";         echo "email 为: ". $info[$i]["mail"][0] ."<p>";     }     echo "关闭链接";     ldap_close($ds); } else {     echo "<h4>无法连接到 LDAP 服务器</h4>"; } ?> 
 
欲使用 LDAP 服务器功能要先在 Web 服务器安装 LDAP 客户端程序,较着名的有美国密西根大学的 ldap-3.3 套件或者是 Netscape 的 Directory SDK。可到下列网址找回来安装 
 
 |