我想通过LDAP接收用户的给定名称(也是显示名称)。
我使用以下代码:
$ldap = ldap_connect("ldap://domain.com");
ldap_set_option($ldap, LDAP_OPT_PROTOCOL_VERSION, 3);
ldap_set_option($ldap, LDAP_OPT_REFERRALS, 0);
if ($bind = ldap_bind($ldap, $myusername, $mypassword))
{
$_SESSION['login_user'] = $myusername;
$filter = "(sAMAccountName={$myusername})";
$ldap_dn = "dc=domain, dc=com";
$attr = array("givenname");
$result = ldap_search($ldap, $ldap_dn, $filter, $attr) or exit("Unable to search LDAP server");
$entries = ldap_get_entries($ldap, $result);
$givenname = $entries[0]['givenname'][0];
ldap_unbind($ldap);
setcookie("name", $givenname, time() + (86400 * 30), "/");
setcookie("sessao", $local, time() + (86400 * 30), "/"); // 86400 = 1 dia
//header("location: welcome.php");
}
每当我登录时,在欢迎页面中,cookie“name”为空,所以我删除了重定向以查看发生了什么。
现在我收到以下错误:
Notice: Undefined offset: 0 in C:\wamp\www\OperPHP\authentication.php on line 21
观察:第21行是:
$givenname = $entries[0]['givenname'][0];
我想我的LDAP查询中有些东西,但我不知道它在哪里。
任何人都可以提供帮助吗?
@EDIT
当我使用echo print_r($entries);
时,它会显示Array ( [count] => 0 ) 1
!这意味着我的$entries
没有收到任何价值。
答案 0 :(得分:1)
我很确定你的过滤器很古怪。根据我在那里阅读的内容,您的过滤器实际上为用户名为janedoe的用户查找:
(sAMAccountName={janedoe})
我会删除大括号,看看它是否有效。