2

我正在使用 LDAP 创建一个身份验证中间件应用程序,但我很难让搜索工作。

我正在使用 Mocha 进行测试,并创建了一个 util.js 来创建一个模拟 ldapjs 服务器:

let server = require('../mocks/ldapServer');
const ldap = require('ldapjs');    

let ldapEntities = {
  'cn=root,dc=example,dc=com,o=example': {
    dn: 'cn=root,dc=example,dc=com',
    objectclass: 'organizationalRole',
    cn: 'Manager'
  },
  'cn=ABC,dc=example,dc=com,o=example': {
    dn: 'cn=ABC,dc=example,dc=com,o=example',
    objectclass: 'organizationalUnit',
    cn: 'ABC'
  },
  'cn=Bob Johnson,ou=ABC,dc=example,dc=com,o=example': {
    cn: 'Bob Johnson',
    dn: 'cn=Bob Johnson,ou=ABC,dc=example,dc=com,o=example',
    sn: 'Johnson',
    objectClass: 'inetOrgPerson'
  },
  'cn=Don Doddson,dc=example,dc=com,o=example': {
    cn: 'Don Doddson',
    dn: 'cn=Don Doddson,dc=example,dc=com,o=example',
    sn: 'Doddson',
    objectClass: 'inetOrgPerson',
    userPassword: 'rubbishpassword'
  }
};    

before(done => {
  server.start(1389, () => {    

    let ldapClient = ldap.createClient({
      url: process.env.DIRECTORY_SYSTEM_AGENT
    });    

    ldapClient.bind(process.env.LDAP_ADMIN, process.env.LDAP_SECRET, error => {    

      if (error) {
        return console.log('Error binding to LDAP: ' + error.message);
      }    

      //Bound to server, creating test accounts
      for (let i in ldapEntities) {
        ldapClient.add(i, ldapEntities[i], error => {
          if (error) {
            console.error(error);
          }
        });
      }    

    });
    done();
  });
});    

after(done => {
  server.stop(done);
});

我正在搜索使用:

let dn = 'cn=root,dc=example,dc=com,o=example';
let opts = {
  filter: '(cn=Don Doddson)',
  scope: 'sub'
}

client.search(dn, opts, (error, result) => { ...

没有什么是“破坏”的,但我得到的 SearchEntry messageID 为 2,而不是我想要的详细信息。

谢谢!

4

2 回答 2

1

看起来像是ldapEntities定义中root 的dn打印错误

dn: 'cn=root,dc=example,dc=com, o=example ',

于 2016-08-29T15:36:21.080 回答
1

问题是我没有为每个 ldapEntities 设置终点。

于 2016-08-30T09:03:22.883 回答