Node.js刷新session过期时间

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Node.js刷新session过期时间相关的知识,希望对你有一定的参考价值。

  在Node.js中,我们通常使用express-session这个包来使用和管理session,保存服务端和客户端浏览器之间的会话状态。那如何才能实现当用户刷新当前页面或者点击页面上的按钮时重新刷新session的过期时间呢?类似于ASP.NET中session会话状态,只要在一定的时间内页面一直保持活动状态,session就不会过期。通过下面的代码可以实现这个功能,我们在Node.js的代码中加入下面的中间件:

// use this middleware to reset cookie expiration time
// when user hit page every time
app.use(function(req, res, next){
    req.session._garbage = Date();
    req.session.touch();
    next();
});

  这样,每次当有请求过来时,该中间件都会重新修改session的过期时间,从而达到预期的效果。

  然后,在代码中加入对session的使用:

app.use(session({
        secret: ‘test‘, 
        resave: false, 
        saveUninitialized: true,
        cookie:{
            maxAge: 1000*60*60 // default session expiration is set to 1 hour
        },
        store: new MemcachedStore({
            hosts: [‘127.0.0.1:9000‘],
            prefix: ‘test_‘
        })
}));

  上面的session使用了memcached作为session的存储方式,有关如何使用memcached可以参考Github上的这个地址https://github.com/balor/connect-memcached

  当然,你也可以使用其它的session存储方式,例如memoryStore,redis,mongoDB等等,使用方法都大同小异。

以上是关于Node.js刷新session过期时间的主要内容,如果未能解决你的问题,请参考以下文章

每次刷新或访问页面时,Node js express-session都会创建新的会话ID

在 SessionStore 而不是 cookie 中设置 Node.js Express 会话过期时间

Node.js学习笔记

session过期时ajax请求刷新浏览器

快速中间件中的 Node.js JWT 刷新令牌

没有 req.session.save() 会话不会保存在 Node.js 中