Ldapjs在一段时间后连接超时

ldapjs connection times out after certain period of time

本文关键字:连接 超时 一段时间 Ldapjs      更新时间:2023-09-26

我在使用LDAPjs的LDAP存储库中有一些关于searchEntry的问题。我不是很熟悉LDAP,因此我可能在客户机实现中遗漏了一些东西。问题是,经过一段时间后,LDAP服务器没有响应,没有调用任何回调。

  const ldapClient = ldap.createClient({
      url: 'ldap://some.ldap.server',
      timeout: 3000,
      connectTimeout: 6000
    });
  ldapClient.search('c=XX', opts, (err, res) => {
    if (err) {
      ldapClient.unbind(function(err) {
        if (err) {
          console.log(err)
        }
      });
      return next(null);
    }
  res.once('searchEntry', (entry) => {
    ldapClient.unbind(function(err) {
      if (err) {
      console.log(err)
      }
    });
    return next(entry);
  });
  res.on('error', (error) => {
    ldapClient.unbind(function(err) {
      if (err) {
      console.log(err)
      }
    });
    return next(null, new Error(error.message));
  });
});

在创建LDAP客户端时将reconnect标志传递为true,不要像您那样解除对它的绑定。我想这也阻碍了重新连接。只有在搜索成功后才能解除绑定。

这段代码为我工作:(值当然是假的)

var ldap = require('ldapjs');
var tlsOptions = {
    host: 'example.com',
    port: '636',
    ca: [fs.readFileSync('./path/to/cert.pem')]
};
var client = ldap.createClient({
    url: 'ldaps://example.com:636',
    reconnect: true
    tlsOptions: tlsOptions
});
client.bind(username, password, function (err) {
    if (err) {
        console.log('Error occurred while binding');
    } else {
        var base = 'cn=admin,dc=example,dc=com';
        var search_options = {
            scope: 'sub',
            filter: '(&(objectClass=*)(CN=' + username + '))',
            attrs: 'attrs'
        };
        client.search(base, search_options, function (err, res) {
            if (err) {
                console.log('Error occurred while ldap search');
            } else {
                res.on('searchEntry', function (entry) {
                    console.log('Entry', JSON.stringify(entry.object));
                });
                res.on('searchReference', function (referral) {
                    console.log('Referral', referral);
                });
                res.on('error', function (err) {
                    console.log('Error is', err);
                });
                res.on('end', function (result) {
                    console.log('Result is', result);
                });
            }
        });
    }
});