【发布时间】: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 连接重新连接后,该会话才会被破坏。您可以断开与服务器的套接字连接。