express——存储cookie和session

cookie

安装cookie-parser

npm i cookie-parser -D

最基础用法

const express = require('express');
const cookieParser = require('cookie-parser');

let server = express();
server.listen(8081)

//use引入
server.use(cookieParser())

server.get('/a', (req, res) => {
    //设置key为amount,value为99.8
    res.cookie('amount', 99.8, {
        //存储时间
        maxAge: 14 * 86400 * 1000
    })
    res.send('ok')
})

所有客户端的存储都是不安全的,我们可以给cookie设置签名

有签名的cookie,不能通过客户端修改

const express = require('express');
const cookieParser = require('cookie-parser');

let server = express();
server.listen(8081)
//使用签名可以一定程度解决安全性问题,但是签名会占空间,cookie存储空间只有4k,这是个缺点
server.use(cookieParser(
    'madapao'
))

server.get('/a', (req, res) => {
	//没有签名的cookie
    console.log('cookie', req.cookies)
	//有签名的cookie
    console.log('signed', req.signedCookies)

    res.cookie('amount', 99.8, {
        //httpOnly: true, //只能通过服务器修改
        //secure: true, //只有https可以修改
        maxAge: 14 * 86400 * 1000,
        signed: true   //开启签名 
    })
    res.send('ok')
})

效果在这里插入图片描述

session

安装cookie-session

const express = require('express')
const cookieSession = require('cookie-session')

let server = express();
server.listen(8081)
//通过session鉴定身份。没有的话,就是第一次访问 
server.use(cookieSession({
    //多设置几组密匙
    keys: ['343rfdsfdsf', '3rrerereffbfg5676', '3fdfdsfdsfds'],
    maxAge: 20 * 60 * 1000
}))

server.get('/a', (req, res) => {
    if (!req.session['view']) {
        req.session['view'] = 1;
    } else {
        req.session['view']++
    }
    res.send(`欢迎你第${req.session['view']}到访本网站`)
})

效果
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

因市场原因,有关experss的课程目前只讲这些基础。对数据库操作和实际项目的应用,我们将在koa中详细讲解

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值