完整的 LDAP + phpLDAPadmin安装部署流程 (ubuntu18.04)
LDAP 安装部署以及基础使用
因工作需求需要使用ldap管理用户权限,在踩了一系列坑之后,总结了一些流畅的文档,希望可以帮到和曾经的我一样迷茫的人。
基础环境:Ubuntu 18.04
一、安装
root@cky:~# apt install slapd ldap-utils -y
Administrator password: 123456
Confirm password: 123456
安装包版本
root@cky:~/ldap# dpkg -l slapd ldap-utils
Desired=Unknown/Install/Remove/Purge/Hold
| Status=Not/Inst/Conf-files/Unpacked/halF-conf/Half-inst/trig-aWait/Trig-pend
|/ Err?=(none)/Reinst-required (Status,Err: uppercase=bad)
||/ Name Version Architecture Description
+++-===============================================-============================-============================-===================================================================================================
ii ldap-utils 2.4.45+dfsg-1ubuntu1.10 amd64 OpenLDAP utilities
ii slapd 2.4.45+dfsg-1ubuntu1.10 amd64 OpenLDAP server (slapd)
二、配置
配置组织名称,输入/验证在安装期间创建的管理员密码。完成后,选择MDB作为数据库后端,然后在清除slapd时选择No以删除数据库。最后,选择Yes以移动旧数据库,完成安装和配置。
root@cky:~# dpkg-reconfigure slapd
Omit OpenLDAP server configuration? No
DNS domain name: company.com
Organization name: company
Administrator password: 123456
Confirm password: 123456
Database backend to use: MDB
Do you want the database to be removed when slapd is purged? No
Move old database? Yes
验证一下
通过LDAP协议(仅列出dn),这是slapd-config DIT的样子:
root@cky:~# ldapsearch -Q -LLL -Y EXTERNAL -H ldapi:/// -b cn=config dn
dn: cn=config
dn: cn=module{0},cn=config
dn: cn=schema,cn=config
dn: cn={0}core,cn=schema,cn=config
dn: cn={1}cosine,cn=schema,cn=config
dn: cn={2}nis,cn=schema,cn=config
dn: cn={3}inetorgperson,cn=schema,cn=config
dn: olcBackend={0}mdb,cn=config
dn: olcDatabase={-1}frontend,cn=config
dn: olcDatabase={0}config,cn=config
dn: olcDatabase={1}mdb,cn=config
条目说明:
- cn = config:全局设置
- cn = module {0},cn = config:动态加载的模块
- cn = schema,cn = config:包含硬编码的系统级架构
- cn = {0} core,cn = schema,cn = config:硬编码核心架构
- cn = {1} cosine,cn = schema,cn = config:余弦模式
- cn = {2} nis,cn = schema,cn = config:nis模式
- cn = {3} inetorgperson,cn = schema,cn = config:inetorgperson模式
- olcDatabase = {-1} frontend,cn = config:前端数据库,其他数据库的默认设置
- olcDatabase = {0} config,cn = config:slapd配置数据库(cn = config)
- olcDatabase = {1} mdb,cn = config:您的数据库实例(dc = example,dc = com)
这是dc = company,dc = com DIT的样子:
root@cky:~# ldapsearch -x -LLL -H ldap:/// -b dc=company,dc=com dn
dn: dc=company,dc=com
dn: cn=admin,dc=company,dc=com
查询当前用户
root@cky:~# ldapwhoami -x
anonymous
root@cky:~# ldapwhoami -x -D cn=admin,dc=company,dc=com -W
Enter LDAP Password: 123456
dn:cn=admin,dc=company,dc=com
填充一波数据库
创建ldif文件
root@cky:~/ldap# pwd
/root/ldap
root@cky:~/ldap# cat ldap_data.ldif
dn: ou=Dev,dc=company,dc=com
objectClass: organizationalUnit
ou: Dev
dn: ou=Groups,dc=company,dc=com
objectClass: organizationalUnit
ou: Groups
dn: cn=miners,ou=Groups,dc=company,dc=com
objectClass: posixGroup
cn: miners
gidNumber: 5000
dn: uid=zhangsan,ou=Dev,dc=company,dc=com
objectClass: inetOrgPerson
objectClass: posixAccount
objectClass: shadowAccount
uid: zhangsan
sn: Zhang
givenName: San
cn: zhangsan
displayName: ZS
uidNumber: 10001
gidNumber: 10001
userPassword: zspwd
gecos: zhangsan
loginShell: /bin/bash
homeDirectory: /mnt/zs
使用以下命令将文件内容添加到LDAP:
root@cky:~/ldap# ldapadd -x -D cn=admin,dc=company,dc=com -W -f ldap_data.ldif
Enter LDAP Password: 123456
adding new entry "ou=Dev,dc=company,dc=com"
adding new entry "ou=Groups,dc=company,dc=com"
adding new entry "cn=miners,ou=Groups,dc=company,dc=com"
adding new entry "uid=zhangsan,ou=Dev,dc=company,dc=com"
咱们来查一下:
# 查一个
root@cky:~/ldap# ldapsearch -x -b "uid=zhangsan,ou=Dev,dc=company,dc=com"
root@cky:~/ldap# ldapsearch -x -LLL -b dc=company,dc=com 'uid=zhangsan' ou Dev
# 查多个
root@cky:~/ldap# ldapsearch -x -LLL -b dc=company,dc=com ou DEV
此时我们可以看到,用户已添加成功。
此时,ldap已安装部署完成。
三、基础使用方法
添加用户:
root@cky:~/ldap# cat add_lisi.ldif
dn: uid=lisi,ou=Dev,dc=company,dc=com
objectClass: inetOrgPerson
objectClass: posixAccount
objectClass: shadowAccount
uid: lisi
sn: Li
givenName: Si
cn: lisi
displayName: LS
uidNumber: 10002
gidNumber: 10002
userPassword: lspwd
gecos: lisi
loginShell: /bin/bash
homeDirectory: /mnt/ls
root@cky:~/ldap# ldapadd -x -D cn=admin,dc=company,dc=com -W -f add_lisi.ldif
Enter LDAP Password: 123456
adding new entry "uid=lisi,ou=Dev,dc=company,dc=com"
查询用户:
root@cky:~/ldap# ldapsearch -x -LLL -b dc=company,dc=com 'uid=lisi' ou Dev
dn: uid=lisi,ou=Dev,dc=company,dc=com
修改用户信息:
root@cky:~/ldap# cat modify_lisi.ldif
dn: uid=lisi,ou=Dev,dc=company,dc=com
changetype: modify
replace: displayName
displayName: LiSi
root@cky:~/ldap# ldapmodify -x -D 'cn=admin,dc=company,dc=com' -W -f modify_lisi.ldif
Enter LDAP Password:
modifying entry "uid=lisi,ou=Dev,dc=company,dc=com"
删除用户:
root@cky:~/ldap# ldapdelete -x -D 'cn=admin,dc=company,dc=com' -w 123456 -r "uid=lisi,ou=Dev,dc=company,dc=com"
root@cky:~/ldap# ldapsearch -x -LLL -b dc=company,dc=com 'uid=lisi' ou Dev
root@cky:~/ldap#
更改rootDN密码:
- 首先,运行
slappasswd获取所需的新密码的哈希值:
root@cky:~/ldap# slappasswd
New password: 654321
Re-enter new password: 654321
{SSHA}PkliLbd6Dih/H34i626AA22Eok1vdG76
- 准备一个
changerootpw.ldif具有以下内容的文件:
root@cky:~/ldap# cat changerootpw.ldif
dn: olcDatabase={1}mdb,cn=config
changetype: modify
replace: olcRootPW
olcRootPW: {SSHA}PkliLbd6Dih/H34i626AA22Eok1vdG76
- 最后,运行
ldapmodify命令:
root@cky:~/ldap# ldapmodify -Q -Y EXTERNAL -H ldapi:/// -f changerootpw.ldif
modifying entry "olcDatabase={1}mdb,cn=config"
配置日志
创建logging.ldif具有以下内容的文件:
dn: cn=config
changetype: modify
replace: olcLogLevel
olcLogLevel: stats
修改
root@cky_dev:~/cky/ldap# ldapmodify -Q -Y EXTERNAL -H ldapi:/// -f logging.ldif
modifying entry "cn=config"
phpLDAPadmin
如果是和我一样的初学者,建议搭起来看一下效果,会帮助你加深对ldap的理解。
一、安装
安装PHP和Apache Web服务器:
# 该存储库包含迄今为止的所有发行版本的PHP。
root@cky:~# add-apt-repository ppa:ondrej/php
root@cky:~# apt update
root@cky:~# apt install php7.0 php7.0-xml php7.0-ldap php7.0-cgi apache2 libapache2-mod-php7.0 php-mbstring php-common -y
启用php7.0-cgi扩展:
root@cky_test01:~# a2enmod php7.0
root@cky_test01:~# a2enconf php7.0-cgi
root@cky_test01:~# systemctl reload apache2
安装phpLDAPadmin:
root@cky_test01:~# apt -y install phpldapadmin
查看一下版本
root@cky:~# dpkg -l phpldapadmin
Desired=Unknown/Install/Remove/Purge/Hold
| Status=Not/Inst/Conf-files/Unpacked/halF-conf/Half-inst/trig-aWait/Trig-pend
|/ Err?=(none)/Reinst-required (Status,Err: uppercase=bad)
||/ Name Version Architecture Description
+++-===============================================-============================-============================-===================================================================================================
ii phpldapadmin 1.2.2-6ubuntu1.1 all web based interface for administering LDAP servers
就这里,php版本和phpLDAPadmin版本对应的坑就坑了我很久,别的版本我不太清楚,就我上面的版本肯定是没问题的。
二、配置
修改phpLDAPadmin配置:
root@cky:~# vim /etc/phpldapadmin/config.php
286 $servers->setValue('server','name','company LDAP Server');
300 $servers->setValue('server','base',array('dc=company,dc=com'));
326 $servers->setValue('login','bind_id','cn=admin,dc=company,dc=com');
修改/etc/apache2/conf-enabled/phpldapadmin.conf上的访问权限,以允许仅从你信任的子网进行访问:
# 大概在20行的位置,放行了自己就行
Order deny,allow
Deny from all
Allow from 127.0.0.1 192.168.1.0/24
重启apache2
root@cky_test01:~# systemctl restart apache2
防火墙放行
root@cky:~# ufw allow ldap
Rules updated
Rules updated (v6)
# 测一下
root@cky:~# ldapwhoami -H ldap:// -x
anonymous
三、访问
现在,登录访问一下phpldapadmin吧
http://xxx.xxx.xxx.xxx/phpldapadmin/
额外赠送一个小知识:在已安装的PHP版本之间切换
有两种方法:Apache2、CLI
Apache2
root@cky_test01:~# cd /etc/apache2/
root@cky_test01:/etc/apache2# ls -l mods-*/*php*
-rw-r--r-- 1 root root 867 Jan 12 06:03 mods-available/php5.6.conf
-rw-r--r-- 1 root root 102 Jan 12 06:03 mods-available/php5.6.load
-rw-r--r-- 1 root root 855 Oct 7 11:24 mods-available/php7.2.conf
-rw-r--r-- 1 root root 102 Oct 7 11:24 mods-available/php7.2.load
lrwxrwxrwx 1 root root 29 Dec 20 20:59 mods-enabled/php7.2.conf -> ../mods-available/php7.2.conf
lrwxrwxrwx 1 root root 29 Dec 20 20:59 mods-enabled/php7.2.load -> ../mods-available/php7.2.load
# 禁用
root@cky_test01:/etc/apache2# a2dismod php7.2
root@cky_test01:/etc/apache2# a2disconf php7.2-cgi
# 启用
root@cky_test01:/etc/apache2# a2enmod php5.6
root@cky_test01:/etc/apache2# a2disconf php5.6-cgi
root@cky_test01:/etc/apache2# systemctl restart apache2
CLI
root@cky_test01:/etc/apache2# update-alternatives --set php /usr/bin/php5.6
update-alternatives: using /usr/bin/php5.6 to provide /usr/bin/php (php) in manual mode
# 或者
root@cky_test01:/etc/apache2# update-alternatives --config php
There are 2 choices for the alternative php (providing /usr/bin/php).
Selection Path Priority Status
------------------------------------------------------------
0 /usr/bin/php7.2 72 auto mode
* 1 /usr/bin/php5.6 56 manual mode
2 /usr/bin/php7.2 72 manual mode
Press <enter> to keep the current choice[*], or type selection number:
完整的 LDAP + phpLDAPadmin安装部署流程 (ubuntu18.04)的更多相关文章
- OpenStack Keystone安装部署流程
之前介绍了OpenStack Swift的安装部署,采用的都是tempauth认证模式,今天就来介绍一个新的组件,名为Keystone. 1. 简介 本文将详细描述Keystone的安装部署流程,并给 ...
- Python web项目Django部署在Ubuntu18.04腾讯云主机上
Django2.1 + Python3.6 + nginx + uwsgi 部署到Ubuntu18.04 材料准备 准备一个Django项目 准备一台Ubuntu18.04的主机 ssh连接到主机(腾 ...
- Janus安装教程,ubuntu18.04系统
Janus安装教程,ubuntu18.04系统 本文介绍Jansu如何安装,操作系统为Ubuntu 18.04. (1)安装git 执行命令:“sudo apt-get install ...
- LDAP + Samba 安装配置流程
LDAP + Samba 安装配置 基础环境:Ubuntu18.04 安装samba root@cky:~# apt install samba smbldap-tools -y 查看版本 root@ ...
- GeoServer安装部署流程
1.双击geoserver-2.13.0.exe进行安装,点击Next进行下一步 2.GeoServer遵循GPL许可,点击I agree继续 3.选择要安装的程序文件目录,点击Next继续 4.点击 ...
- Win10 安装 Linux子系统 Ubuntu18.04 / Kali Linux 的体验
汇总系列:https://www.cnblogs.com/dunitian/p/4822808.html#linux 几年前就看到新闻,今天周末,突发奇想,家里电脑安装下子系统不就不用安装开发的那些环 ...
- VirtualBox安装部署的Ubuntu16.04的步骤
1.下载ubuntu16.04镜像 http://cn.ubuntu.com/download/ 以及虚拟机软件VirtualBox https://www.virtualbox.org/wiki/D ...
- Nginx安装教程,ubuntu18.04
本文介绍Nginx如何安装,操作系统为Ubuntu 18.04. 一.安装 (1)安装git 执行命令:“sudo apt-get install git”. (2)安装aptitude 执行命令 ...
- OpenStack Swift集群部署流程与简单使用
之前介绍了<OpenStack Swift All In One安装部署流程与简单使用>,那么接下来就说一说Swift集群部署吧. 1. 简介 本文档详细描述了使用两台PC部署一个小型Sw ...
随机推荐
- 前端基础之html学习一:
网站的建站流程 页面图例 网页的结构 WEB标准 WEB标准是网页制作的标准,它不是一个标准,它是根据网页的不同组成部分生成的一系列标准.这些标准大部分由W3C起草发布,也有部分标准由ECMA起草发布 ...
- c#的dllimport使用方法详解(Port API)
DllImport是System.Runtime.InteropServices命名空间下的一个属性类,其功能是提供从非托管DLL(托管/非托管是微软的.net framework中特有的概念,其中, ...
- Berry Jam (前缀和)cf教育场
距离上一篇博客又2个月了 寻思着该除除草了 教育场是真的好难 可能是因为我还是只菜鸡 哭唧唧 先说下题意:有2*n罐果酱,草莓和蓝莓,梯子在中间从梯子那开始往两边吃(可以一会左一会右),问最少吃多少果 ...
- python实现通过指定浏览器免费观看vip视频
程序是先通过一个解析视频的网站,然后我们提取其接口,然后实现观看vip视频的目的 所以说免费观看视频python程序很容易,但是下载视频就有些许麻烦了,下载视频请见我另一篇博客:python+fidd ...
- http post请求数组参数写法
1.json形式 body如下(注意是中括号): [ *, *, * ] postman: fiddler: 2.x-www-form-urlencoded postman: fiddler: 3.服 ...
- volatile的内存屏障的坑
请看下面的代码并尝试猜测输出: 可能一看下面的代码你可能会放弃继续看了,但如果你想要彻底弄明白volatile,你需要耐心,下面的代码很简单! 在下面的代码中,我们定义了4个字段x,y,a和b,它们被 ...
- STM32F107移植LWIP
STM32F107上移植LWIP2.0.3 因为最近需要在STM32F107上实现TCP/IP协议栈,所以网上查了一下,准备使用LWIP,虽然大多数用的是1.4.1版本但是官方说2系大版本修复了1.4 ...
- 虚拟环境之间批量pip安装包"迁移"
在某个虚拟环境中通过 pip freeze > requirements.txt 将该环境下所有的包写入文档, 然后切换至另一虚拟环境, pip install -r requirements. ...
- Vue & Sentry sourcemaps All In One
Vue & Sentry sourcemaps All In One vue & sentry & sourcemaps https://docs.sentry.io/plat ...
- 蓝湖 UI 设计稿上如何生成渐变色和复制渐变色
蓝湖 UI 设计稿上如何生成渐变色和复制渐变色 Sketch 生成渐变色 不要上传图片,切图 如果是切图,切图模式下就不会生成 css 代码了 复制渐变色 OK .button { width: 28 ...