2

我在 socket.io 上构建了一个 nodejs 应用程序中继,使用 Passport 和 passport.socketio 进行身份验证和授权,使用 mongodb 和 connect-mongo 进行会话存储。

它在我的笔记本电脑上运行良好,但是当我迁移到云 (Azure-VM) 时,我开始遇到奇怪的错误。

2014 年 5 月 2 日,11:47:06.500 监听端口 8081 (https)

/home/azureuser/myapp/node_modules/mongodb/lib/mongodb/connection/base.js:242
    throw message;      
          ^
Error: Error in session store:
Error: failed to deserialize user out of session
    at Object.io.set.passportSocketIo.authorize.fail     (/home/azureuser/myapp/lib/express/socketio.js:25:23)
    at /home/azureuser/myapp/node_modules/passport.socketio/lib/index.js:48:21
    at /home/azureuser/myapp/node_modules/connect-mongo/lib/connect-mongo.js:229:23
    at /home/azureuser/myapp/node_modules/mongodb/lib/mongodb/collection/query.js:147:5
    at Cursor.nextObject (/home/azureuser/myapp/node_modules/mongodb/lib/mongodb/cursor.js:733:5)
    at commandHandler (/home/azureuser/myapp/node_modules/mongodb/lib/mongodb/cursor.js:713:14)
    at /home/azureuser/myapp/node_modules/mongodb/lib/mongodb/db.js:1806:9
    at Server.Base._callHandler (/home/azureuser/myapp/node_modules/mongodb/lib/mongodb/connection/base.js:442:41)
    at /home/azureuser/myapp/node_modules/mongodb/lib/mongodb/connection/server.js:485:18
    at MongoReply.parseBody (/home/azureuser/myapp/node_modules/mongodb/lib/mongodb/responses/mongo_reply.js:68:5)

任何想法从哪里开始?

4

1 回答 1

3

好的,我找到了,passport.socketio 依赖于 Passport,并且有自己的“版本”护照。这意味着在我的代码中,当我设置 serializeUser/deserializeUser 时,它只会影响我用于 REST 的护照:

passport.serializeUser(function(user, done) {
    done(null, user);
});
passport.deserializeUser(function(id, done) {
    done(null, id);
}); 

虽然 passport.socketio 默认情况下会:

var defaults = {
  passport:     require('passport'),
  key:          'connect.sid',
  secret:       null,
  ...
};

这意味着未使用 serializeUser/deserializeUser,这反过来会导致:

Error: failed to deserialize user out of session

解决方案非常简单,只需将用于 REST 的护照传递给 passport.socketio

io.set('authorization', passportSocketIo.authorize({
    passport : passport,
    cookieParser: express.cookieParser,
    ...
 }));
于 2014-02-05T16:13:39.050 回答