【发布时间】:2019-02-21 00:39:37
【问题描述】:
我搜索了我的问题,发现完全相同的here 没有答案,this 没有帮助,this 也没有,所以我在这里问。
我有一个 openldap
版本
(版本 slapd (Ubuntu) (May 22 2018 13:54:12) $ buildd@bos02-arm64-019:/build/openldap-AktVWV/openldap-2.4.42+dfsg/debian/build/servers/slapd)
在 odroid hc1 上运行良好(我可以使用 PAM_ldap 在某些 VM 上进行身份验证)和 jenkins(2.138 版)在我的本地机器上运行良好。
当我将 jenkins 配置为使用 ldap 对用户进行身份验证时出现问题。 使用“测试 ldap 设置”按钮测试设置时,查找正常
查找用户查找:成功用户ID:测试用户Dn: "cn=test+gidNumber=5556+givenName=test+homeDirectory=/home/test+loginShell=/bin/bash+sn=test+uid=test,ou=users",dc=home,dc=local 用户显示名称:test 用户电子邮件:test@home.local LDAP 组 成员资格:jenkins LDAP 组查找:成功(1 个组)
但登录失败并显示锁定警告消息
用户“test”将无法使用提供的密码登录。如果 这是您自己的帐户,这意味着您将被锁定!是 您确定要保存此配置吗?
这是 jenkins 中的 ldap 配置:
Server: ldap://192.168.1.106
root DN: dc=home,dc=local
User search filter: uid={0}
Group membership: Search for LDAP groups containing user
Manager DN: cn=admin,dc=home,dc=local
Manager Password: ••••••••••
Display Name LDAP attribute: uid
Email Address LDAP attribute: mail
当 jenkins 登录失败时,ldap 的日志显示如下:
slapd[844]: conn=1254 op=0 do_bind: 无效 dn ("cn=test+gidNumber=5556+givenName=test+homeDirectory=/home/test+loginShell=/bin/bash+sn=test+uid=test,ou=users",dc=home,dc=local)
注意ou=users 后面的双引号。这似乎是一个连接问题?
jenkins 计算并发送到 openldap 的 dn 无效,应该是
("cn=test+gidNumber=5556+givenName=test+homeDirectory=/home/test+loginShell=/bin/bash+sn=test+uid=test,ou=users,dc=home,dc=local")
如果我使用 Apache Directory Studio 并使用无效 dn 发出搜索,它会失败(显然),如果我使用固定 dn 搜索,搜索会返回预期的记录。
Openldap 不允许匿名绑定,因此 jenkins 配置中的管理员凭据。
我尝试添加/删除根 dn(如果缺少则测试失败)、搜索库(无论是否填充测试失败)、搜索组(相同)。
我有点想不出办法来解决这个问题。
我一定是错过了什么。
感谢任何帮助。
编辑:添加测试用户 ldif
dn: cn=test+gidNumber=5556+givenName=test+homeDirectory=/home/test+loginShel
l=/bin/bash+sn=test+uid=test,ou=users,dc=home,dc=local
objectClass: simpleSecurityObject
objectClass: posixAccount
objectClass: top
objectClass: person
objectClass: organizationalPerson
objectClass: inetOrgPerson
cn: test
gidNumber: 5556
homeDirectory: /home/test
sn: test
uid: test
uidNumber: 5556
userPassword:: e1NTSEF9aCtmbmhraXVJSXp1MmRETUY4Zm4wK3NpYzVrUEF6VXJmWUhKUmc9P
Q==
givenName: test
loginShell: /bin/bash
mail: test@home.local
Edit2:我安装了免费的人工制品。我能够成功添加 ldap 设置并使用相同的测试用户测试身份验证,而 ldap 配置或树没有任何变化。
【问题讨论】: