3

我在 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;
    },

};

当我第一次验证我的用户时,它运行良好,但从第二次尝试开始失败。错误消息是:'write after end'

当我重新启动节点服务器时,它会在第一次尝试时再次运行。

好像有什么东西挂了,但我不知道是什么。任何的想法?

4

1 回答 1

1

几天前我解决了这个问题,每次在 ldapBind 函数中创建 ldap-client (在你的情况下)。

于 2014-09-18T12:37:56.200 回答