ldap_bind():无法绑定到服务器:无法联系LDAP服务器

时间:2015-06-24 15:44:06

标签: php ldap

我可以使用管理员用户名和密码进行远程访问,我在脚本中使用相同的用户名和密码。但是我收到以下错误

警告:ldap_bind():无法绑定到服务器:无法联系LDAP服务器

无法绑定到服务器。检查用户名/密码。 服务器响应: 错误号码:-1 描述:无法联系LDAP服务器

<?php
    ini_set('display_errors',1);
    ini_set('display_startup_errors',1);
    error_reporting(-1);

     // Username used to connect to the server
     $username = "Administrator";

     // Password of the user.
     $password = "password";

     // Either an IP or a domain.
     $ldap_server = "10.10.10.10";

     // Get a connection
     $ldap_conn = ldap_connect($ldap_server);

     // Set LDAP_OPT_PROTOCOL_VERSION to 3
     ldap_set_option($ldap_conn, LDAP_OPT_PROTOCOL_VERSION, 3) or die ("Could not set LDAP Protocol version");

     // Authenticate the user and link the resource_id with
     // the authentication.
     if($ldapbind = ldap_bind($ldap_conn, $username, $password) == true)
     {
     // Setup the data that will be used to create the user
     // This is in the form of a multi-dimensional
     // array that will be passed to AD to insert.
     $adduserAD["cn"] = "testuser";
     $adduserAD["sn"] = "User";
     $adduserAD["samaccountname"] = "testuser";
     $adduserAD["objectClass"] = "user";
     $adduserAD["displayname"] = "Test User";
     $adduserAD["userPassword"] = "Welcome123!";
     $adduserAD["userAccountControl"] = 544;

     $base_dn = "cn=testuser,cn=Users,DC=testdomain,DC=com";

     // Display some "waiting" text.
     echo "Trying to add the user to the system ...<br>";

     // Attempt to add the user with ldap_add()
     if(ldap_add($ldap_conn, $base_dn, $adduserAD) == true)
     {

     // The user is added and should be ready to be logged
     // in to the domain.
     echo "User added!<br>";
     }else{

     // This error message will be displayed if the user
     // was not able to be added to the AD structure.
     echo "Sorry, the user was not added.<br>Error Number: ";
     echo ldap_errno($ldap_conn) . "<br />Error Description: ";
     echo ldap_error($ldap_conn) . "<br />";
     }
     }else{
     echo "Could not bind to the server. Check the username/password.<br />";
     echo "Server Response:"

     // Error number.
     . "<br />Error Number: " . ldap_errno($ldap_conn)

     // Error description.
     . "<br />Description: " . ldap_error($ldap_conn);
     }

     // Always make sure you close the server after
     // your script is finished.
     ldap_close($ldap_conn);
    ?> 

2 个答案:

答案 0 :(得分:-1)

您应该检查首次ldap_connect(...)来电的结果。

尝试something like this or this验证您的所有连接信息。这对我来说非常有帮助,以确保您拥有正确的帐户信息和LDAP目录信息。

答案 1 :(得分:-1)

为什么以下行没有端口?

$ldap_server = "10.10.10.10";
$ldap_conn = ldap_connect($ldap_server);

尝试类似下面的内容

 if($authMethod == 0){
    $ldap_server = 'ldap://'.$host.':'.$port;
}else if($authMethod == 1) {
    $ldap_server = 'ldaps://'.$host.':'.$port;
}
$ldap_conn = ldap_connect($ldap_server);

然后检查$ ldap_conn是true还是false或任何其他返回码。 端口#389是简单LDAP的默认值,636是LDAPS。 我希望这应该工作:)。干杯!!!!