ldap_compare
(PHP 4 >= 4.0.2, PHP 5, PHP 7, PHP 8)
ldap_compare — Compare value of attribute found in entry specified with DN
說明
LDAP\Connection
$ldap,string
$dn,string
$attribute,string
$value,?array
$controls = null): bool|int
   Compare value of attribute
   with value of same attribute in an LDAP directory entry.
  
參數
- 
ldap
- 
      通過 ldap_connect() 返回的 LDAP\Connection 實例。 
- 
dn
- 
      The distinguished name of an LDAP entity. 
- 
attribute
- 
      The attribute name. 
- 
value
- 
      The compared value. 
- 
controls
- 
      Array of LDAP Controls to send with the request. 
返回值
   Returns true if value matches otherwise returns
   false. Returns -1 on error.
  
更新日誌
| 版本 | 說明 | 
|---|---|
| 8.1.0 | 現在 ldap參數接受 LDAP\Connection
  實例,之前接受 資源(resource)。 | 
| 8.0.0 | controlsis nullable now; previously, it defaulted to[]. | 
| 7.3.0 | Support for controlsadded | 
範例
The following example demonstrates how to check whether or not given password matches the one defined in DN specified entry.
示例 #1 Complete example of password check
<?php
$ds=ldap_connect("localhost");  // assuming the LDAP server is on this host
if ($ds) {
    // bind
    if (ldap_bind($ds)) {
        // prepare data
        $dn = "cn=Matti Meikku, ou=My Unit, o=My Company, c=FI";
        $value = "secretpassword";
        $attr = "password";
        // compare value
        $r=ldap_compare($ds, $dn, $attr, $value);
        if ($r === -1) {
            echo "Error: " . ldap_error($ds);
        } elseif ($r === true) {
            echo "Password correct.";
        } elseif ($r === false) {
            echo "Wrong guess! Password incorrect.";
        }
    } else {
        echo "Unable to bind to LDAP server.";
    }
    ldap_close($ds);
} else {
    echo "Unable to connect to LDAP server.";
}
?>
註釋
ldap_compare() can NOT be used to compare BINARY values!