ホームページ > バックエンド開発 > PHPチュートリアル > LDAP シリーズ - 第 3 章 - PHP-LDAP

LDAP シリーズ - 第 3 章 - PHP-LDAP

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-13 12:33:41
オリジナル
992 人が閲覧しました

LDAP-Series-1-Chapter-3 - PHP-LDAP

LDAP で PHP を使用する場合。拡張子 lib.(ldap.so)

を追加する必要があります。

PHP のインストール ファイルに移動します。

$ cd /opt/php-5.4.5/ext/ldap/
$ /usr/local/bin/phpize
$ ./configure --with-php-config=/usr/local/bin/php-config --with-ldap=/usr/local/openldap
$ make
$ make install
$ cd /usr/local/lib
$ vi php.ini (<strong>extension-dir=/usr/local/lib extension=php_ldap.so</strong>)
$ cp /usr/local/lib/php/ext/..../ldap.so /usr/local/lib/php_ldap.so
ログイン後にコピー
パスは自由に変更できます。

$ php -v
ログイン後にコピー
エラーが存在するかどうかを確認します。 (今まで、私の職場の PHP は ldap.so を読み込めません)

PHP テスト ファイル。

<?php
class m_ldap{
        private $ldapHost = "127.0.0.1";
        private $ldapPort = 389;
        private $ds;
        function m_ldap_con(){
                $this->ds = ldap_connect($this->ldapHost,$this->ldapPort) or die("Could not connect to $this->ldapHost");
                return true;
        }
        function m_ldap_bind($dn,$psw){
                ldap_set_option($this->ds, LDAP_OPT_PROTOCOL_VERSION, 3);
                if($this->ds){
                        $r = ldap_bind($this->ds,$dn,$psw) or die("Could not bind to $dn");
                        if($r){
                                return true;
                        }else{
                                return false;
                        }
                }else{
                        return false;
                }
        }
        function m_ldap_add($dn,$info){
                $r=ldap_add($this->ds,$dn,$info);
                if($r){
                        return true;
                }else{
                        return false;
                }
        }

        function m_ldap_modify($dn,$info){
                $r=ldap_modify($this->ds,$dn,$info);
                if($r){
                        return true;
                }else{
                        return false;
                }
        }

        function m_ldap_search($dn,$filter){
                $ldapSearch = ldap_search($this->ds,$dn,$filter);
                $ldapInfo = ldap_get_entries($this->ds,$ldapSearch);
                return $ldapInfo;
        }
}

?>
ログイン後にコピー
ldap_set_option($this->ds, LDAP_OPT_PROTOCOL_VERSION, 3); //DS でプロトコル バージョン 3 を使用するようにします。そうでない場合は、プロトコルに関するエラーが発生します。

<?php
        require_once("m_ldap.php");
        $mdap=new m_ldap();
        $mdap->m_ldap_con();
        $dn = "cn=root,ou=SystemAdmin,dc=xxx,dc=org";
        $psw= "xxxxxx";

        $mdap->m_ldap_bind($dn,$psw) or die("cannot bind");
        
        $sdn="ou=people,ou=iWeb,dc=weiwejia,dc=org";
        $filter="(uid=*)";
        $res=$mdap->m_ldap_search($sdn,$filter);

        foreach( $res[0]["cn"] as $key=>$val){
                print $key."\n";
                print $val."\n";
        }
?>
ログイン後にコピー
すべてが正常であれば、すぐに動作します。 (ACL のサポートが必要です。次の章を参照してください。)




関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート