1

我是 LDAP 新手。

我正在使用 nodejs 的ldapauth并且我不断得到32 - No Such Object.

这是我的代码:

var LdapAuth = require('ldapauth');
var ldapOptions = {
    "url":"ldap://my-host:389",
    "adminDn" : "cn=manager,dc=guycrc,dc=com",
    "adminPassword":"secret",
    "searchBase":"ou=Engineering",
    "searchFilter":"(uid={{username}})"
};

var ldapAuthClient = new LdapAuth( ldapOptions );

ldapAuthClient.authenticate('Dana', 'Dana',
    function(err, result) {
        if (err) {
            console.log(['Error',err.code, err.dn, err.message ]);
        } else {
            console.log('Credentials valid = ' + result); // true or false
        }
    }
);

这是我的 LDAP 信息 - 我认为与问题相关

dn: cn=Dana,ou=people,dc=guycrc,dc=com
...
cn: Dana Dana
sn: Dana
uid: Dana
userpassword: Dana
ou: Engineering


dn: cn=CompanyA,ou=groups,dc=guycrc,dc=com
...
cn: CompanyA
ou: Groups
member: cn=Dana,ou=people,dc=guycrc,dc=com

为什么我总是得到No Such Object

4

2 回答 2

2

搜索库对象ou=engineering可能不是预期的,该值看起来不像 DN,而是像 RDN。使用完整且正确的搜索基础对象,它将是优于客户端搜索对象的 DN。

也可以看看

于 2013-07-01T15:32:04.910 回答
2

不确定.authenticate在您的行中是什么意思: ldapAuthClient.authenticate('Dana', 'Dana',

我猜根据错误传递的数据不足以找到所需的对象。

查看您定义的选项:

"searchBase":"ou=Engineering",
"searchFilter":"(uid={{username}})"

表示它正在 ou=engineering 容器中查找。并寻找与用户名匹配的 uid,因此作为 uid 部分的“Dana”可能是正确的。

但是由于您的 LDIF 向 Dana 显示了 DN: dn: cn=Dana,ou=people,dc=guycrc,dc=com

不在 ou=engineering 中。

也许就像将您的 searchBase 更改为 ou=people,dc=guycrc,dc=com 一样简单

于 2013-07-01T14:30:08.730 回答