nodejs passport ldapauth"无法阅读' on'未定义的财产"

时间:2015-02-27 20:18:38

标签: node.js ssl ldap passport.js

我正在尝试使用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

有人可以帮助我吗?

感谢。

2 个答案:

答案 0 :(得分:5)

最后,我可以解决这个问题。

ldapauth-fork中使用的ldapjs版本无法使用ldaps url。

解决方案是:

  1. 从ldapauth-fork目录下的node_modules目录中删除ldapjs(在我的用户!!!!!!的node_modules中的passport-ldap下的其他node_modules目录下)以下命令:

    npm rm ldapjs

  2. 使用以下命令从github安装新版本:

    npm install git://github.com/mcavage/node-ldapjs.git

  3. FDO。

答案 1 :(得分:2)

使用SSL时,只有Node 0.12和io.js会发生这种情况,请参阅ldapjs issue。您可以在项目package.json中为未发布的版本添加依赖项:

{
  "dependencies": {
    "ldapjs": "mcavage/node-ldapjs",
    "ldapauth-fork": "2.3.1"
  }
}