【问题标题】:jenkins VS openldap: authentication fails but lookup okjenkins VS openldap:身份验证失败但查找正常
【发布时间】: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 LD​​AP 组 成员资格: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 配置或树没有任何变化。

【问题讨论】:

    标签: jenkins ldap openldap


    【解决方案1】:

    在我发现有效的密码哈希是带有 jenkins 的 SSHA 之前,一直遇到同样的问题。

    【讨论】:

    • 我会尽快试一试,然后告诉你。
    猜你喜欢
    • 2014-10-13
    • 1970-01-01
    • 2021-10-09
    • 1970-01-01
    • 1970-01-01
    • 2013-01-02
    • 2013-10-29
    • 1970-01-01
    • 2016-05-10
    相关资源
    最近更新 更多