我可以使用管理员用户名和密码进行远程访问,我在脚本中使用相同的用户名和密码。但是我收到以下错误
警告: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);
?>
答案 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。 我希望这应该工作:)。干杯!!!!