NodeJS,passport,passport ldap连接错误:ldaps://ldap.XXXX.com:636关



我正试图在windows到Linux机器上部署一个工作的Nodejs服务器。使用passport ldapauth模块登录我们公司的LDAP服务器我得到了:

"ConnectionError:ldaps://ldap.XXX.com:636已关闭"在windows部署中,我没有遇到任何问题,

这是服务器代码:

var express = require('express')
	, http = require('http')
	, express = require('express')
	, routes = require('./routes')
	, http = require('http')
	, passport = require('passport')
	, flash = require('connect-flash')
	, fs = require('fs')
	, ldapStrategy = require('passport-ldapauth')
	, path = require('path');
var ldapGroupName = "XXX_GROUP";
var app = express();
var ldapOptions = {
	server : {
		url : 'ldaps://ldap.XXX.com:636',
		searchBase : 'o=XXX.com',
		searchFilter : '(uid={{username}})',
		tlsOptions : {
			ca : [ fs.readFileSync('/etc/ssl/certs/XXX.crt') ]
		}
	}
};
var opts = {
	filter : '(cn='+ldapGroupName+')',
	scope : 'sub'
};
//configure passport
passport.use(new ldapStrategy(ldapOptions));
var app = express();
var server = http.createServer(app);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.use(express.favicon());
app.use(express.logger()); 
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.json({limit: '50mb'}));
app.use(express.urlencoded({limit: '50mb'}));
app.use(express.session({secret:'Password'})); 
app.use(passport.initialize());
app.use(passport.session());
app.use(flash());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'WebContent')));
  passport.serializeUser(function(user, done) {
	done(null, user);
});
passport.deserializeUser(function(id, done) {
	done(null, id);
});
   app.post('/login', function(req, res, next) {
	passport.authenticate('ldapauth', function(err, user, info) {
		if (info) {
			console.log('info: ' + info.message);
			res.send({
				status : 'err',
				message : info.message
			});
			return;
		}
		if (err) {
			console.log('err: ' + err);
			res.send({
				status : 'err',
				message : err
			});
			return;
		}
		if (!user) {
			return res.redirect('/');
		}
		req.logIn(user, function(err) {
			req.session.cookie.expires = new Date(Date.now() + 1000 * 60 * 30); 
			if (err) {
				return next(err);
			}
			return res.send({
				status : 'ok' , 
				name : user.givenName
			});
		});
	})(req, res, next);
});
server.listen(4002);
console.log("started port: 4002");

我是不是错过了什么?我需要安装证书吗?

好的,我设法找到了答案,在顶部的server.js中添加了:

process.env.NODE_TLS_REJECT_UNAUTHORIZED="0";

感谢:使用node.js和ldapjs的LDAP绑定错误

最新更新