详解nodejs express下使用redis管理session


Posted in NodeJs onApril 24, 2017

Session实现原理

实现请求身份验证的方式很多,其中一种广泛接受的方式是使用服务器端产生的Session ID结合浏览器的Cookie实现对Session的管理,一般来说包括以下4个步骤:

1.服务器端的产生Session ID

2.服务器端和客户端存储Session ID

3.从HTTP Header中提取Session ID

4.根据Session ID从服务器端的Hash中获取请求者身份信息 

使用Express和Redis对Session管理的实现

var session = require('express-session');
var RedisStrore = require('connect-redis')(session);
var config={
"cookie" : {
  "maxAge" : 1800000
},
 "sessionStore" : {
  "host" : "192.168.0.13",
  "port" : "6379",
  "pass" : "123456",
  "db" : 1,
  "ttl" : 1800,
  "logErrors" : true
}

app.use(session({
  name : "sid",
  secret : 'Asecret123-',
  resave : true,
  rolling:true,
  saveUninitialized : false,
  cookie : config.cookie,
  store : new RedisStrore(config.sessionStore)
}));

实现堆栈
express-session实例化后调用代码(https://github.com/expressjs/session)

if (!req.sessionID) {

  debug('no SID sent, generating session');

  generate();

  next();

  return;

 }

generate方法调用(https://github.com/expressjs/session)

store.generate = function(req){

  req.sessionID = generateId(req);

  req.session = new Session(req);

  req.session.cookie = new Cookie(cookieOptions);

 

  if (cookieOptions.secure === 'auto') {

   req.session.cookie.secure = issecure(req, trustProxy);

  }

 };

RedisStrore实例化时调用store.set(sid, session, callback)(https://github.com/expressjs/session)

store.set调用RedisStore.prototype.set(https://github.com/tj/connect-redis),其中座位hashkey使用的是前缀+sessonId,前缀默认值为'sess',多个应用共享和不共享同一个redis session服务时,一定要注意设置prefix

RedisStore.prototype.set = function (sid, sess, fn) {

  var store = this;

  var args = [store.prefix + sid];

  if (!fn) fn = noop;

 

  try {

   var jsess = store.serializer.stringify(sess);

  }

  catch (er) {

   return fn(er);

  }

 

  args.push(jsess);

 

  if (!store.disableTTL) {

   var ttl = getTTL(store, sess);

   args.push('EX', ttl);

   debug('SET "%s" %s ttl:%s', sid, jsess, ttl);

  } else {

   debug('SET "%s" %s', sid, jsess);

  }

 

  store.client.set(args, function (er) {

   if (er) return fn(er);

   debug('SET complete');

   fn.apply(null, arguments);

  });

 };

store.client.set调用的为(https://github.com/NodeRedis/node_redis)

最终调用原生redis.hset方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
golang、python、php、c++、c、java、Nodejs性能对比
Mar 12 NodeJs
NodeJS的url截取模块url-extract的使用实例
Nov 18 NodeJs
轻松创建nodejs服务器(3):代码模块化
Dec 18 NodeJs
轻松创建nodejs服务器(4):路由
Dec 18 NodeJs
nodejs中的fiber(纤程)库详解
Mar 24 NodeJs
nodejs创建web服务器之hello world程序
Aug 20 NodeJs
Nodejs初级阶段之express
Nov 23 NodeJs
Jquery通过ajax请求NodeJS返回json数据实例
Nov 08 NodeJs
详解nodejs 文本操作模块-fs模块(三)
Dec 22 NodeJs
nodejs结合socket.io实现websocket通信功能的方法
Jan 12 NodeJs
Linux Centos7.2下安装nodejs&npm配置全局路径的教程
May 15 NodeJs
nodejs实现UDP组播示例方法
Nov 04 NodeJs
nodejs入门教程六:express模块用法示例
Apr 24 #NodeJs
Nodejs进阶:express+session实现简易登录身份认证
Apr 24 #NodeJs
nodejs入门教程五:连接数据库的方法分析
Apr 24 #NodeJs
nodejs入门教程四:URL相关模块用法分析
Apr 24 #NodeJs
nodejs入门教程三:调用内部和外部方法示例
Apr 24 #NodeJs
nodejs入门教程二:创建一个简单应用示例
Apr 24 #NodeJs
nodejs入门教程一:概念与用法简介
Apr 24 #NodeJs
You might like
Discuz!X中SESSION机制实例详解
2015/09/23 PHP
HR vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
javascript表单验证 - Parsley.js使用和配置
2013/01/25 Javascript
js窗口关闭提示信息(兼容IE和firefox)
2015/10/23 Javascript
javascript运动框架用法实例分析(实现放大与缩小效果)
2016/01/08 Javascript
js实现select选择框效果及美化
2016/08/19 Javascript
Js获取当前日期时间及格式化代码
2016/09/17 Javascript
node.js 发布订阅模式的实例
2017/09/10 Javascript
vue2实现可复用的轮播图carousel组件详解
2017/11/27 Javascript
Vue封装Swiper实现图片轮播效果
2018/02/06 Javascript
Vue实现导航栏点击当前标签变色功能
2020/08/19 Javascript
如何使用CSS3和JQuery easing 插件制作绚丽菜单
2019/06/18 jQuery
vue 实现在同一界面实现组件的动态添加和删除功能
2020/06/16 Javascript
[05:53]完美世界携手游戏风云打造 卡尔工作室观战系统篇
2013/04/22 DOTA
[01:10:27]DOTA2-DPC中国联赛正赛 SAG vs XG BO3 第二场 3月5日
2021/03/11 DOTA
python网络编程实例简析
2014/09/26 Python
django模型中的字段和model名显示为中文小技巧分享
2014/11/18 Python
编写Python脚本来实现最简单的FTP下载的教程
2015/05/04 Python
python实现ping的方法
2015/07/06 Python
Python简单网络编程示例【客户端与服务端】
2017/05/26 Python
使用Python写一个贪吃蛇游戏实例代码
2017/08/21 Python
django启动uwsgi报错的解决方法
2018/04/08 Python
Python字符串对象实现原理详解
2019/07/01 Python
python matplotlib 画dataframe的时间序列图实例
2019/11/20 Python
美国领先的奢侈美容零售商:Bluemercury
2017/07/26 全球购物
行政人员工作职责
2013/12/05 职场文书
函授教育个人学习的自我评价
2013/12/31 职场文书
写求职信要注意什么问题
2014/04/12 职场文书
霸气押韵的班级口号
2014/06/09 职场文书
2014年宣传思想工作总结
2014/12/10 职场文书
2015年小学语文工作总结
2015/05/25 职场文书
毕业生自我鉴定范文
2019/05/13 职场文书
Python实现简繁体转换
2021/06/07 Python
用JS实现飞机大战小游戏
2021/06/09 Javascript
mysql 直接拷贝data 目录下文件还原数据的实现
2021/07/25 MySQL
进行数据处理的6个 Python 代码块分享
2022/04/06 Python