express中操作cookie和session

express中操作cookie和session

一、操作cookie:

  1. 设置cookie(给客户端“种”cookie):

    直接使用res.cookie(‘key’,‘value’,{maxAge:??????})即可。

  2. 获取cookie(要第三方中间件):

    • 安装: npm i cookie-parser
    • 引入: const cookieParser = require('cookie-parser')
    • 使用: app.use(cookieParser())
  3. 测试:返回给客户端一个cookie:

    • res.cookie('username','peiqi',{maxAge:1000*60*60})

    备注:
    1.cookie是以:key-value的形式存在的,前两个参数分别为:key、value。
    2.maxAge用于配置cookie有效期(单位毫秒)。
    3.如果不传入maxAge配置对象,则为会话cookie,随着浏览器的关闭cookie自动会消失。
    4.如果传入maxAge,且maxAge不为0,则cookie为持久化cookie,即使用户关闭浏览器,cookie也不会消失,直到过了它的有效期。

  4. 测试:接收客户端传递过来的cookie:

    • req.cookies.xxx :获取cookie上xxx属性对应的值。

    备注:cookie-parser中间件会自动把客户端发送过来的cookie解析到request对象上。


二、操作session:

  1. 下载安装:

    npm i express-session --save  //用于在express中操作session
    
  2. 引入express-session模块:

    const session = require('express-session');
    
  3. 编写全局配置对象:

     app.use(session({
            name: 'userid',   //设置cookie的name
            secret: 'wul', //参与加密的字符串(又称签名)
            saveUninitialized: false, //是否在存储内容之前创建会话
            resave: true ,//是否在每次请求时,强制重新保存session,即使他们没有变化
            cookie: {
               httpOnly: true, // 开启后前端无法通过 JS 操作cookie
               maxAge: 1000*30 // 设置cookie的过期时间
            },
        }));
    
  4. 向session中添加一个xxxx,值为yyy:

    req.session.xxxx = yyy
    
  5. 获取session上的xxx属性:

    const {xxx} = req.session
    

三、扩展:session的持久化

  1. 下载安装:

    npm i connect-mongo --save //用于将session写入数据库(session持久化)
    
  2. 引入express-session模块:

    const session = require('express-session');
    
  3. 引入connect-mongo模块:

    const MongoStore = require('connect-mongo')(session);
    
  4. 编写全局配置对象:

    app.use(session({
        ...
        store: new MongoStore({
            url: 'mongodb://localhost:27017/sessions_container',
            touchAfter: 24 * 3600 //修改频率(例://在24小时之内只更新一次)
        }),
        ...
    }));
    

整个过程是:
1. 客户端第一次发起请求,服务器开启一个session专门用于存储这次请求的一些信息。
2. 根据配置对象的信息,服务器决定是否进行:session持久化等其他操作。
3. 与此同时服务器创建了一个cookie,它的key我们可以自己指定,但是它的value一定是上一步session的唯一标识。
4. 服务器将我们指定好的内容添加进session对象,例如:req.session.xxxx = yyy。
5. 等请求再次过来时,客户端的请求中包含着之前“种”的cookie。
6. 服务器检查携带过来的cookie是否有效,决定是否去读取对应session中的信息。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值