我使用Node.js和ldapjs中的以下代码创建了一个身份验证服务。
var when = require ('when');
var AuthenticationError = require('../errors/AuthenticationError');
var SessionManagerService = require('./SessionManagerService');
var ldap = require('ldapjs');
var client = ldap.createClient({
url: 'ldaps://ad.mycompany.com:636',
tlsOptions: {'rejectUnauthorized': false}
});
module.exports = {
signIn: function (email, password) {
return this.ldapBind(email, password).then(
function () {
return SessionManagerService.createSessionHash({email: email});
}
);
},
ldapBind: function (email, password) {
var deferred = when.defer();
client.bind(email, password, function(err) {
if (err) {
deferred.reject (new AuthenticationError('Invalid username and/or password!', 'Authentication.signIn.error'));
} else {
client.unbind();
deferred.resolve(true);
}
});
return deferred.promise;
},
};
当我第一次对用户进行身份验证时,它可以正常运行但是从第二次尝试开始失败。 错误消息为:'写完后'。
当我重新启动节点服务器时,它会再次运行第一次尝试。
看起来有些事情悬而未决,但我不知道是什么。有什么想法吗?
答案 0 :(得分:1)
我几天前解决了这个问题,每次都在ldapBind函数中创建ldap-client(在你的情况下)。