node.js 中间件express-session使用详解

这篇文章主要给你们介绍了node.js中间件express-session使用的相关资料,文中介绍的很是详细,对你们具备必定的参考学习价值,须要的朋友们下面来一块儿看看吧。前端

本文介绍的关于node.js中间件express-session的相关内容,分享出来供你们从参考学习,下面来一块儿看看详细的介绍:node

1、为何使用session

session运行在服务器端,当客户端第一次访问服务器时,能够将客户的登陆信息保存。
当客户访问其余页面时,能够判断客户的登陆状态,作出提示,至关于登陆拦截。
session能够和Redis或者数据库等结合作持久化操做,当服务器挂掉时也不会致使某些客户信息(购物车)丢失。数据库

2、session的工做流程:

当浏览器访问服务器并发送第一次请求时,服务器端会建立一个session对象,生成一个相似于key,value的键值对, 而后将key(cookie)返回到浏览器(客户)端,浏览器下次再访问时,携带key(cookie),找到对应的session(value) 。 客户的信息都保存在session中。express

3、express-session的经常使用参数:

secret:一个String类型的字符串,做为服务器端生成session的签名。
name:返回客户端的key的名称,默认为connect.sid,也能够本身设置。
resave:(是否容许)当客户端并行发送多个请求时,其中一个请求在另外一个请求结束时对session进行修改覆盖并保存。
默认为true。可是(后续版本)有可能默认失效,因此最好手动添加。
saveUninitialized:初始化session时是否保存到存储。默认为true, 可是(后续版本)有可能默认失效,因此最好手动添加。
cookie:设置返回到前端key的属性,默认值为{ path: ‘/', httpOnly: true, secure: false, maxAge: null }浏览器

  • express-session的一些方法:服务器

  • Session.destroy() :删除session,当检测到客户端关闭时调用。cookie

  • Session.reload() :当session有修改时,刷新sessionsession

  • Session.regenerate() :将已有session初始化。并发

  • Session.save() :保存sessionapp

4、示例demo

//app.js中添加以下代码(已有的不用添加)
var express = require('express');
var cookieParser = require('cookie-parser');
var session = require('express-session');
 
app.use(cookieParser('sessiontest'));
app.use(session({
 secret: 'sessiontest',//与cookieParser中的一致
 resave: true,
 saveUninitialized:true
}));
//修改router/index.js,第一次请求时咱们保存一条用户信息。
router.get('/', function(req, res, next) {
 var user={
  name:"Chen-xy",
  age:"22",
  address:"bj"
 }
 req.session.user=user;
 res.render('index', {
  title: 'the test for nodejs session' ,
  name:'sessiontest'
 });
});
//修改router/users.js,判断用户是否登录。
router.get('/', function(req, res, next) {
 if(req.session.user){
  var user=req.session.user;
  var name=user.name;
  res.send('你好'+name+',欢迎来到个人家园。');
 }else{
  res.send('你尚未登陆,先登陆下再试试!');
 }
});

总结
好了,以上就是这篇文章的所有内容了,但愿本文的内容对你们的学习或者工做能带来必定的帮助,若是有疑问你们能够留言交流,谢谢你们对脚本之家的支持。
原文连接:http://blog.csdn.net/u0126795...

相关文章
相关标签/搜索