express框架中session持久化存储

express框架中session持久化存储

admin
2020-01-03 / 0 评论 / 546 阅读 / 正在检测是否收录...

在web开发中,我们经常后听到前端程序员的依据抱怨"又重启了啊?我又要重新登录",这是因为在传统的web开发中,服务器一旦关机,内存中的会话信息会丢失,就跟前端开发存在变量中的数据,浏览器刷新后会丢失一样。为了解决这个问题,引入了session持久化的概念,将服务端和客户端的会话信息保存到一个载体中,不管服务器怎么重启,只要载体中的信息没有丢失,就能拿到会话信息,载体一般为数据库或者文件,但是,得益于redis的特性,我们一般选择用redis作为存储载体。下面是nodejs中用redis做session持久化的例子

// app.js
var session = require('express-session');
var RedisStore = require('connect-redis')(session);
var radisOptions = {
    'host': 'localhost',
    'port': '6379',
    'ttl': 7200, // 存储时间,单位秒,这个时间要和下面session中间件的cookie选项时间一致
    'logErrors': false
  };
var sessionOptions = {
  secret : 'secret', // 对session id 相关的cookie 进行签名
  resave : true,
  rolling: true,
  saveUninitialized: true, // 是否保存未初始化的会话
  cookie : {
      maxAge : 1000 * 60 * 60 * 2, // 设置 session 的有效时间,单位毫秒 这里设置两小时
  },
};
// 生产环境开启持久化存储
if (config.get('enviroment') === 'prod') {
  sessionOptions.store = new RedisStore(radisOptions)
}
app.use(session(sessionOptions));
0

评论 (0)

取消