Apache Directory Studio を利用してユーザをOpenLDAPに登録します。 OpenLDAPに登録されたユーザでApacheのBasic認証を行えるようにします。 ディレクトリ別の認証とか難しいことはまずは無視します。 【OpenLDAPサーバ】 OS: CentOS 6.3(64-bit) openldap-servers: 2.4.23-26.el6_3.2 hostname: openldap IP: 192.168.77.146 【Webサーバ】 OS: CentOS 6.3(64-bit) Apache: 2.2.15 hostname: web03 IP: 192.168.77.147
■ApacheにLDAPモジュールがインストールされているか確認
[root@web03 ~]# grep ldap /etc/httpd/conf/httpd.conf
LoadModule ldap_module modules/mod_ldap.so
LoadModule authnz_ldap_module modules/mod_authnz_ldap.so
[root@web03 ~]#
※ mod_authnz_ldap:Apache-2.2系でLDAP認証を実現する※ mod_ldap:LDAPサーバとの接続プールやキャッシュ用に使用される(mod_authnz_ldapから利用される)
■Apache Directory Studio にてエントリー作成
ベースDN: dc=open_ldap,dc=comOrganization Unit(部署): unit01
ユーザID: en2011001
※ユーザIDの文字列はEmployee Numberの略のつもり。2011年度入社001番みたいな。
⇒ベースDN作成
objectClassは「dcObject」と「organization」を設定
※objectClassの「top」は自動的に追加される。
data:image/s3,"s3://crabby-images/846d8/846d8eccc00ec65080f0b3ccb85def035aa2907b" alt=""
data:image/s3,"s3://crabby-images/ef047/ef047a459bf11661aaf776b53e49b8f600cac3a9" alt=""
data:image/s3,"s3://crabby-images/9923c/9923c8b7abdbeff96b741ddb5c13c2619d755af2" alt=""
data:image/s3,"s3://crabby-images/6c1c1/6c1c12ca08cdbd30f381681009f92d5f62a4473a" alt=""
data:image/s3,"s3://crabby-images/acebd/acebdebbf87ea480b2fe686fe4aa41411d734ee3" alt=""
data:image/s3,"s3://crabby-images/fe14e/fe14ed4d2fbc1ba38107ee46e82173cf5fb4ee54" alt=""
⇒Organization Unit(部署)作成
objectClassは「organizationalUnit」を設定
data:image/s3,"s3://crabby-images/97f05/97f05b299b85aeb772627b2457bc05ebcbba36a0" alt=""
data:image/s3,"s3://crabby-images/7fd65/7fd655d91ca9a5daa0e172b96f38debf881e6d2c" alt=""
data:image/s3,"s3://crabby-images/74e0a/74e0a1967e6c0268c73de6aa051c66a069f25aa2" alt=""
data:image/s3,"s3://crabby-images/edcce/edcce132298de3bfc2ba969154c29ad55d2b0fbb" alt=""
data:image/s3,"s3://crabby-images/d7245/d72457dc3fb52edf10d7e5d02e5706d65d457eee" alt=""
data:image/s3,"s3://crabby-images/89a25/89a25282df767403a651c1850783a842596197a3" alt=""
⇒ユーザ作成
objectClassは「account」と「posixAccount」を設定
※作成手順はobjectClassが異なるだけでouとほぼ同等のため省略
data:image/s3,"s3://crabby-images/d0b5d/d0b5d4bfc6211e0c4478aa139920c33ec75791ba" alt=""
⇒ユーザにパスワードを設定する
data:image/s3,"s3://crabby-images/de233/de233f84411858c126109dd91a33e71393c4f87f" alt=""
data:image/s3,"s3://crabby-images/47b43/47b43c43fbe8289f56f67408ba944cd4ac7ad4dd" alt=""
data:image/s3,"s3://crabby-images/ba4b7/ba4b7f79156f8e167f09faa17159e2473ca60098" alt=""
■OpenLDAPサーバで作成状況確認
[root@openldap ~]# ldapsearch -x -h localhost -b "dc=open_ldap,dc=com"
# extended LDIF
#
# LDAPv3
# base with scope subtree
# filter: (objectclass=*)
# requesting: ALL
#
# open_ldap.com
dn: dc=open_ldap,dc=com
dc: open_ldap
o: open_ldap
objectClass: dcObject
objectClass: top
objectClass: organization
# unit01, open_ldap.com
dn: ou=unit01,dc=open_ldap,dc=com
ou: unit01
objectClass: organizationalUnit
objectClass: top
# en2011001, unit01, open_ldap.com
dn: uid=en2011001,ou=unit01,dc=open_ldap,dc=com
uid: en2011001
gidNumber: 1000
cn: en2011001
homeDirectory: /home/en2011001
objectClass: account
objectClass: top
objectClass: posixAccount
uidNumber: 1001
userPassword:: e1NTSEF9RkdNenFHdzJlalExUFlYUHRHUllxQmtFWnJUNjJ5azltR20yRXc9PQ=
=
# search result
search: 2
result: 0 Success
# numResponses: 4
# numEntries: 3
[root@openldap ~]#
■Webサーバ確認用ページ準備
[root@web03 ~]# mkdir /var/www/html/unit01
[root@web03 ~]# vi /var/www/html/unit01/index.html
[root@web03 ~]# cat /var/www/html/unit01/index.html
<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body bgcolor="#dddddd">
<h2>unit01へログインしました。</h2>
</body>
</html>
[root@web03 ~]#
※表示の都合上タグを"<"と">"で記載。(以下同様)■WebサーバBasic認証設定
⇒httpd.confの最下行に下記を追加
[root@web03 ~]# tail -8 /etc/httpd/conf/httpd.conf
<Directory "/var/www/html/unit01/">
AuthName "UserID/Password"
AuthType Basic
AuthBasicProvider ldap
AuthzLDAPAuthoritative off
AuthLDAPURL ldap://192.168.77.146:389/ou=unit01,dc=open_ldap,dc=com?uid?sub?(objectClass=account)
Require valid-user
</Directory>
[root@web03 ~]#
※「AuthzLDAPAuthoritative off」→LDAP認証で失敗しても他の認証サービスを利用しない。※ポート番号(389)の指定は省略可能。
⇒apache再起動
[root@web03 ~]# /etc/init.d/httpd restart
■ブラウザで確認
http://192.168.77.147/unit01/data:image/s3,"s3://crabby-images/6731c/6731ca1803bfe8cc2739bcb23de0f47282dc02b2" alt=""
data:image/s3,"s3://crabby-images/fbcf4/fbcf4ec9b2680b936f11cf96c788776f8d1704b4" alt=""
⇒その時のWebサーバのログ
[root@web03 ~]# tail -f /var/log/httpd/access_log
---
192.168.77.21 - - [26/Jan/2013:04:04:21 +0900] "GET /unit01/ HTTP/1.1" 401 481 "-" "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0; Trident/5.0)"
192.168.77.21 - en2011001 [26/Jan/2013:04:06:00 +0900] "GET /unit01/ HTTP/1.1" 200 187 "-" "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0; Trident/5.0)"
192.168.77.21 - - [26/Jan/2013:04:06:01 +0900] "GET /favicon.ico HTTP/1.1" 404 289 "-" "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0; Trident/5.0)"
最後までお読みいただきありがとうございます。この情報が何かのお役にたてれば幸いです。m(_ _)m
0 件のコメント:
コメントを投稿