我在使用LDAPjs的LDAP存储库中有关于searchEntry的一些问题。我对LDAP不是很熟悉,因此我可能在客户端实现中遗漏了一些东西。问题是,经过一段时间的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));
});
});
答案 0 :(得分:1)
在创建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);
});
}
});
}
});