我正在尝试使用passport-ldapauth和express来验证LDAP服务器。
使用ldap url(ldap:// myserver ...)的身份验证工作正常,但是我得到了ldaps:
TypeError: Cannot read property 'on' of undefined at setupSocket (...\ldapauth-fork\node_modules\ldapjs\lib\client\client.js:111:14) at Client._connect (...\ldapauth-fork\node_modules\ldapjs\lib\client\client.js:742:3) at new Client (...\ldapauth-fork\node_modules\ldapjs\lib\client\client.js:247:22) at Object.createClient (...\ldapauth-fork\node_modules\ldapjs\lib\client\index.js:60:12) at new LdapAuth (...\ldapauth-fork\lib\ldapauth.js:129:28) at handleAuthentication (...\passport-ldapauth\lib\passport-ldapauth\strategy.js:140:10) at Strategy.authenticate (...\passport-ldapauth\lib\passport-ldapauth\strategy.js:175:33) at attempt (...\passport\lib\middleware\authenticate.js:341:16) at authenticate (...\passport\lib\middleware\authenticate.js:342:7) at Layer.handle [as handle_request] (...\express\lib\router\layer.js:82:5)
我的代码基本上是这样的:
...
passport.use(new LdapStrategy({
server: {
url: 'ldaps://myserver:636',
searchBase: '...',
searchFilter: '(uid={{username}})',
tlsOptions: {
ca: [
fs.readFileSync('myCAcert.pem')
]
}
},
session: false,
usernameField:'u',
passwordField:'p'
},
function(user, done) {
console.log("Interna: \nOK");
console.log("u:");
console.log(user.cn);
return done(null, user);
}));
app.use('/login',passport.authenticate('ldapauth',
{ session:false,
successRedirect:'/accessed',
failureRedirect: '/accessfail'
}
));
app.use('/accessed',function (req,res,next){
res.send("User OK");
});
app.use('/accessfail',function (req,res,next){
res.send("User MAL !!!!!!!");
});
app.listen(3336);
我的图书馆版本是:
express@4.11.2, passport@0.2.1,passport-ldapauth@0.3.0
有人可以帮助我吗?
感谢。
答案 0 :(得分:5)
最后,我可以解决这个问题。
ldapauth-fork中使用的ldapjs版本无法使用ldaps url。
解决方案是:
从ldapauth-fork目录下的node_modules目录中删除ldapjs(在我的用户!!!!!!的node_modules中的passport-ldap下的其他node_modules目录下)以下命令:
npm rm ldapjs
使用以下命令从github安装新版本:
npm install git://github.com/mcavage/node-ldapjs.git
FDO。
答案 1 :(得分:2)
使用SSL时,只有Node 0.12和io.js会发生这种情况,请参阅ldapjs issue。您可以在项目package.json
中为未发布的版本添加依赖项:
{
"dependencies": {
"ldapjs": "mcavage/node-ldapjs",
"ldapauth-fork": "2.3.1"
}
}