首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在ldapjs中搜索

在ldapjs中搜索
EN

Stack Overflow用户
提问于 2020-12-14 16:31:13
回答 1查看 379关注 0票数 0

我正在尝试在我的node.js代码中使用Ldap.js的搜索方法。这是我的客户端代码。它成功添加了一个用户,但搜索新添加的用户没有任何结果。( ldap服务器在https://github.com/osixia/docker-openldap的docker容器中运行)

代码语言:javascript
复制
var ldap = require("ldapjs");
var assert = require("assert");

var client = ldap.createClient({
  url: "ldap://localhost:389",
});

client.bind("cn=admin,dc=example,dc=org", "admin", function (err) {
  assert.ifError(err);
  let newUser = {
    cn: "userId7",
    userPassword: "password",
    objectClass: "person",
    sn: "efub",
  };
  // Here i successfully add this user "userId7"
  client.add(
    "cn=userId7,dc=example,dc=org",
    newUser,
    (err, response) => {
      if (err) return console.log(err);
      return response;
    }
  );

  var options = {
    filter: "(objectClass=*)",
    scope: "sub",
  };
  // Now the search, it runs without error, but does never receive a searchEntry
  client.search(
    "cn=userId7,dc=example,dc=org",
    options,
    function (error, search) {
      console.log("Searching.....");

      client.on("searchEntry", function (entry) {
        console.log("I found a result in searchEntry");
      });

      client.on("error", function (error) {
        console.error("error: " + error.message);
      });

      client.unbind(function (error) {
        if (error) {
          console.log(error.message);
        } else {
          console.log("client disconnected");
        }
      });
    }
  );
});

client.on('error', function (err) {
  if (err.syscall == "connect") {
    console.log(err);
  }
});

此外,如果有用的话,下面是我通过运行docker exec my-openldap-container ldapsearch -x -H ldap://localhost:389 -b dc=example,dc=org -D "cn=admin,dc=example,dc=org" -w admin显示ldap中的所有用户时新添加的用户的样子。

代码语言:javascript
复制
# userId7, example.org
dn: cn=userId7,dc=example,dc=org
cn: userId7
userPassword:: cGFzc3dvcmQ=
objectClass: person
sn: efub

更新:我可以使用外壳命令docker exec ldap-service ldapsearch -LLL -x -D "cn=admin,dc=example,dc=org" -w "admin" -b "cn=userId7,dc=example,dc=org" "(objectclass=*)"成功地搜索到用户"userId7“。如何才能使ldapJS也成功地运行此搜索?

更新2:我也可以通过使用前台"phpLDAPadmin“成功搜索,如下截图所示:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-15 15:00:57

所以我解决了这个问题。正确的client.search代码是:

代码语言:javascript
复制
  client.search(
    "cn=userId7,dc=example,dc=org",
    options,
    function (error, res) {
      console.log("Searching.....");

      res.on("searchEntry", function (entry) {
        console.log("I found a result in searchEntry", JSON.stringify(entry.object));
      });

      res.on("error", function (error) {
        console.error("error: " + error.message);
      });

      client.unbind(function (error) {
        if (error) {
          console.log(error.message);
        } else {
          console.log("client disconnected");
        }
      });
    }
  );

function (error, res) {内部,我通过client.on("searchEntry"而不是res.on("searchEntry"监听事件,因此从搜索结果中遗漏了事件。根本原因是一个典型的复制和粘贴错误,以及在误解事件来源时更改变量。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65285808

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档