PHP程序员小白到大牛集训(12期免息)
Apifox=Postman + Swagger + Mock + JMeter,是接口文档,接口调试,接口 Mock,接口自动化测试一体化协作平台, php中文网推荐使用
广告
作者信息
视频教程分类
推荐视频教程
  • php程序员小白到大牛三个月集训php程序员小白到大牛三个月集训
  • Laravel 9 学习正当时—保姆级教程,想学不会都难!Laravel 9 学习正当时—保姆级教程,想学不会都难!
  • 千万级数据并发解决方案(理论+实战)千万级数据并发解决方案(理论+实战)
  • Laravel基础与实战(模块化)Laravel基础与实战(模块化)
  • 首页 >web前端 >js教程 > 正文

    聊聊node+express怎么操作cookie

    原创2022-06-22 22:01:19935 关注公众号:每天精选资源文章推送
    node+express怎么操作cookie?下面本篇文章就来给大家介绍一下用nodejs操作cookie的方法,希望对大家有所帮助!

    Cookie:有时也用其复数形式 Cookies。类型为“小型文本文件”,是某些网站为了辨别用户身份,进行Session跟踪而储存在用户本地终端上的数据(通常经过加密),由用户客户端计算机暂时或永久保存的信息。


    node操作cookie我们需要cookie-parser模块

    npm i cookie-parser -s

    接下来在我们的文件中引入此模块

    // 引入express模块
    const express = require('express')
    // 实例化express
    const app = express()
    // 操作cookie模块
    const cookieParser = require('cookie-parser');
    // 加入cookie签名
    app.use(cookieParser('真的好离谱')); //使用cookie中间件,加密值为:‘真的好离谱’

    参数详解

    name: 一个唯一确定cookie的名称。
    value: 存储在cookie中字符串的值。
    domain: cookie对于那个域下是有效的,
    path: 表示这个cookie影响到的路径,浏览器会根据这个配置,向指定的域中匹配的路径发送cookie。
    expires: 失效时间,表示cookie何时失效的时间,如果不设置这个时间,浏览器就会在页面关闭时将删除所有的cookie,不过我们也可以自己设置过期时间。
    注意:如果客户端和服务器端设置的时间不一致,使用expires就会存在偏差。
    max-age: 用来告诉浏览器此cookie多久过期(单位是秒),一般的情况下,max-age的优先级高于expires。
    HttpOnly: 告诉浏览器不允许通过脚本document.cookie去更改值,这个值在document.cookie中也是不可见的,但是在http请求会携带这个cookie,
    注意:这个值虽然在脚本中使不可取的,但是在浏览器安装目录中是以文件形式存在的,这个设置一般在服务器端设置的。
    secure:安全标志,指定后,当secure为true时候,在HTTP中是无效的,在HTTPS中才有效,表示创建的cookie只能在HTTPS连接中被浏览器传递到服务器端进行会话验证,如果是HTTP连接则不会传递该信息,所以一般不会被且听到。

    关于读取问题

    • req.cookies:读取到的是我们未加密的cookie;

    • req.signedCookies:读取我们的加密cookie。

    案例

    app.get('/', (req, res) => {
        res.cookie('cart', { items: [1, 2, 3] }, { maxAge: 10000 * 2, httpOnly: true, signed: true, path: '/' });
        res.cookie('user', '张三', { httpOnly: true, path: '/user', signed: true })
        res.send('ok')
        console.log(req.cookies)
        console.log(req.signedCookies)
    })

    在这里插入图片描述

    在这里插入图片描述

    app.get('/user', (req, res) => {
    
        console.log(req.cookies)
        res.send(req.signedCookies)
    })

    在这里插入图片描述

    app.get('/news', function (req, res) {
        res.cookie('Age', '大白', { maxAge: 10000 * 2, httpOnly: true, signed: true })
        res.cookie('Age', '0', { maxAge: 0 }); //删除cookie
        res.send('你好nodejs news')
    })

    在这里插入图片描述

    maxAge0时会删除我们的cookie

    更多node相关知识,请访问:nodejs 教程

    以上就是聊聊node+express怎么操作cookie的详细内容,更多请关注php中文网其它相关文章!

    20期PHP线上班

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    相关文章

    相关视频


    专题推荐