如果您不小心將密碼欄位留空,嘗試重新綁定到非匿名帳戶時,OpenLDAP 函式庫會傳回錯誤 53(伺服器不願意執行)。如果您想對非 dn 的其他欄位進行身份驗證,則必須綁定伺服器兩次。您的程式碼可能如下所示:
<?
function ldapLogin($uname, $pass, $base_dn, $fname, $server, $port){
$ldc=@ldap_connect($server, $port);
if (!$ldc) return ERROR_CODE;
$bn='cn=anonymous-user,'.$base_dn;
$pw='anonymous-pass';
$lbind=@ldap_bind($ldc, $bn, $pw);
if (!$lbind) return ERROR_CODE;
$ureturn=@ldap_search($ldc, $base_dn, "($fname=$uname)", array('dn', 'givenName', 'sn', 'mail'));
$uent=@ldap_first_entry($ldc, $ureturn);
if (!$uent) return ERROR_CODE;
$bn=@ldap_get_dn($ldc, $uent);
//此行應使用 $pass 而不是 $password
$lbind=@ldap_bind($ldc, $bn, $password);
// 現在您可以找到錯誤
echo ldap_error($ltc);
if ($lbind) return true; else return false;
?>
希望這能幫助其他遇到相同錯誤的人。