尝试使用LDAP
搜索目录中某人的信息。除了这个搜索字符串之外,其他一切都有效,但是没有人能够找出问题所在。
结果只是出现一个空集,尽管它以bash返回值。
$result = ldap_search(
$ds,
$base_domain,
'(CN=user)'
) or die("error in search");
<?php
$DEBUGGING = True;
if($DEBUGGING)
{
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
}
$server = 'ldaps://ds.cisco.com';
#$port = 639;
$port = 636;
$ds=ldap_connect($server, $port);
echo "connect result is " . $ds . "<br />";
if ($ds)
{
$r = ldap_bind($ds, $username, $password);
echo "Bind result is " . $r . "<br />";
$base_domain = 'OU=Standard,OU=Cisco Groups,DC=cisco,DC=com';
#$base_domain = 'dc=cisco,dc=com';
#$base_domain = 'OU=Employees,OU=Cisco Groups,DC=cisco,DC=com';
#$result = ldap_search($ds, $base_domain, '(&(CN=selyons))') or die ("error in search");
#$result = ldap_search($ds, $base_domain, '(&(membersOf=CN=it-puppet-masters,OU=Standard,OU=Cisco Groups,DC=cisco,DC=com)(sAMAccountName=*))') or die ("error in search");
$result = ldap_search($ds, $base_domain, '(CN=user)') or die("error in search");
echo "SEARCHING" . "<br />";
#while ($row=mysql_fetch_array($result, MYSQL_NUM))
#{
#print_r($row);
#print($row[0]);
#}
$info = ldap_get_entries($ds, $result);
#$arraystring = print_r($info, true);
echo "<pre>";
print_r($info);
echo "</pre>";
#echo $arraystring;
#print_r($info[699][2][0]);
#print_r($info[699][2][1]);
#print_r($info[699][2][2]);
#print_r($info[699][2][3]);
#print_r($info[699][2][4]);
#print_r($info[699][2]);
#print_r($info[699]);
#$members = $info[0]["member"];
#echo $members;
#for($i = 0; $i < 30; $i++)
#{
#print_r($info[699]);
#}
}
?>
答案 0 :(得分:0)
您正在查看容器OU=Standard,OU=Cisco Groups,DC=cisco,DC=com
以查找CN=user
为真的对象。也许您的意思是(objectClass=user)
或者您真的希望有一个CN
属性设置为user
的对象吗?
这似乎显得难以置信。您可能正在考虑AD默认设置,其中Users容器实际上是一个容器,因此cn=Users
而不是ou=Users
,正如您可能预期的那样(也不是dc=Users
)。