Node.js刷新session过期时间
2023-09-27 14:23:13 时间
在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的Java虚拟机:node-jvm
- 《Node.js区块链开发》——2.5 风险提示
- JS leetcode x 的平方根 题解分析
- 白话js this指向问题
- JS App
- ASP.NET MVC异步验证是如何工作的03,jquery.validate.unobtrusive.js是如何工作的
- Node.js文件系统、路径的操作函数
- 《Redis入门指南》一5.4 Node.js与Redis
- 《Node.js区块链开发》——3.4 DPoS:授权股权证明机制
- 《写给PHP开发者的Node.js学习指南》一1.2 堆栈追踪
- js中的call()和apply()和bind()方法
- [js高手之路] html5 canvas系列教程 - 图片操作(drawImage,clip,createPattern)
- js生成二维码实例
- Node.js性能分析神器Easy-Monitor
- 当Node.js遇见Docker
- 从测试数据来看Node.js和Java EE的性能区别
- 兔子--html,js,php,ASP,ASP.NET,JSP的关系
- JS编辑器获取选择内容的HTML多浏览器兼容性写法(支持Chorme、Firefox)
- node.js 教程
- Node.js基础知识梳理
- 原生js实现元素类名的判存、添加和移除
- js--敏感词屏蔽
- Node.js Zlib模块
- Node.js Command Line Options(命令行参数)
- Node.js 在命令行下执行Console.log()命令时,第二行会打印undefined的原因