在Node.js中,我们通常使用express-session这个包来使用和管理session,保存服务端和客户端浏览器之间的会话状态。那如何才能实现当用户刷新当前页面或者点击页面上的按钮时重新刷新session的过期时间呢?类似于ASP.NET中session会话状态,只要在一定的时间内页面一直保持活动状态,session就不会过期。通过下面的代码可以实现这个功能,我们在Node.js的代码中加入下面的中间件:
@H_403_3@
这样,每次当有请求过来时,该中间件都会重新修改session的过期时间,从而达到预期的效果。
然后,在代码中加入对session的使用:
@H_403_3@
上面的session使用了memcached作为session的存储方式,有关如何使用memcached可以参考Github上的这个地址https://github.com/balor/connect-memcached
当然,你也可以使用其它的session存储方式,例如memoryStore,redis,mongoDB等等,使用方法都大同小异。
下面给大家说说Node.js session 存储的几种方法
node.js session store 有可选的四种方法的性能测试如下:
@H_403_3@
对比得出redis来存储在并发性越多的情况下性能优越。
The session used pages are very simple pages;