php进行LDAP服务验证的实现

前言

由于在网上找到一个开源的php项目,但是需要接入到内部的ldap服务器,所以必须重写项目的登录模块,就涉及到ldap服务的登录验证问题。

在网上看到很多类似的代码,说实话,第一,说明不清楚,第二,代码也经不起推敲

DEMO代码

<?php
// 下面是定义ldap服务相关的变量
// dn是ldap中的数据目录结构    
$ldapSrv = "ldap.oschina.com";
$username = 'eric';
$dn = "cn=users,cn=accounts,dc=oschina,dc=com";
$passwd = '123qwe';

// 建立ldap服务连接
$ds=ldap_connect($ldapSrv);
if($ds) {
    // 进行ldap账号验证,第二参数必须是具体到ldap账号的查询
    // 第二参数:uid=eric,cn=users,cn=accounts,dc=oschina,dc=com
    // 很多代码对于第二个参数只是传入username,这样的无法验证通过的
    $r=ldap_bind($ds, "uid=".$username.",".$dn, $passwd) or die("Unable to connect to LDAP server");
    if($r) {
        // 如果验证通过,进行用户信息的查询
        $sr=ldap_search($ds, $dn, "uid=".$username);
        $info = ldap_get_entries($ds, $sr);
            for ($i=0; $i<$info["count"]; $i++) {
            echo "dn is: " . $info[$i]["dn"] . "<br />";
            echo "first cn entry is: " . $info[$i]["cn"][0] . "<br />";
            echo "first email entry is: " . $info[$i]["mail"][0] . "<br /><hr />";
            }
        ldap_close($ds);
        } else {
            echo "Unable to connect to LDAP server";
        }        
    }
?> 

转载于:https://my.oschina.net/mesopotamia/blog/752100

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值