【问题标题】:Node JS - Express, Socket.io complete session destruction when user logs outNode JS - Express,Socket.io 在用户注销时完成会话销毁
【发布时间】:2014-01-28 06:11:07
【问题描述】:

会话变量是在用户登录系统时创建的。然后我在我的授权代码中加载会话变量。我想在用户注销时销毁该变量。这是一些简化的代码

 store = new express.session.MemoryStore();
 var parseCookie = express.cookieParser('secret');
 app.use(parseCookie);
 app.use(express.session({store: store, key:'sid'}));


    app.post('/login', function(req,res){
       var post = req.body;
       if (post.user == 'hugo' && post.password == '123') 
       {
          req.session.user_name = post.user;
          res.redirect('/mypage');
       } 
       else  res.send('wrong user or pass');
    });


    io.set('authorization', function (data, callback) {

         parseCookie(data, {}, function(prserr) {
            var sess = (data.secureCookies && data.secureCookies['sid']);
            store.load(sess, function(err, session){
               if (err || !session ) { callback('not logged in', false); }
               else { 
                       data.session = session;  // save session
                       callback(null, true); 
                    }
            });     
         });

     });

最后

     app.get('/logout', function (req, res) {
        req.session.destroy();
        /* Here I want to destroy session variable that is declared in 
           authorization code (see above: data.session = session )*/
        res.redirect('/'); 
     }); 

同时通过req.session.destroy() 变量销毁会话 socket.handshake.session.user_name 仍然存在。我也想毁掉它。但我不知道如何在上述位置(在注销代码中)访问所需的变量。

【问题讨论】:

  • 直到您从 Socket 连接重新连接后,该会话才会被破坏。您可以断开与服务器的套接字连接。

标签: node.js express socket.io


【解决方案1】:

您是否考虑过使用Passport?它可能比尝试推出自己的身份验证解决方案更快(也更有效)。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-03-21
    • 2014-01-19
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多