JWT基于Cookie的会话保持,并解决CSRF问题的方案

news/2024/5/18 12:26:45 标签: csrf, cookie, jwt, 浏览器会话

使用JWT进行浏览器接口请求,在使用Cookie进行会话保持传递Token时,可能会存在 CSRF 漏洞问题,同时也要避免在产生XSS漏洞时泄漏Token问题,如下图在尽可能避免CSRF和保护Token方面设计了方案。

要点解释如下:
将JWT存入Cookie的优点是无需显式传递,并且对于 image 和文件下载接口比较友好,但是要特别注意设置 HttpOnly 参数禁止通过JS 的方式获取 Cookie,这样能在系统某些场景发生XSS漏洞时也能避免Cookie泄漏。

但是基于Cookie的缺点是会存在CSRF跨站攻击问题。为了避免CSRF问题可以通过自定义Header方式进行接口调用,所以我们可以在使用Cookie存储传递JWT的基础上,增加一个无实际意义并且唯一的sessionId(同时存入浏览器sessionStorage和JWT内容中),每个接口调用都从sessionStorage中读取sessionId并设置到自定义Header中调用接口传递sessionId,在服务端使用过滤器或者拦截器验证自定义header中sessionId的值是否和JWT中的值一致来保证合法性。

在这里插入图片描述
注:JWT只是防篡改,但是默认情况下它body区域的内容是不加密的,如果你需要存储相对敏感信息在JWT中,可以对内容区域进行加密,在服务端解密读取内容。


(END)


http://www.niftyadmin.cn/n/5402632.html

相关文章

29.openeuler OECA认证模拟题12

单选 1、执行()命令,可以切换到紧急模式。B A、systemctl isolate rescue.target B、systemctl isolate emergency.target C、systemctl rescue D、systemctl set-default name.target 2、使用()启动引导可提高开机后操作系统的启动速度 A A、UEFI B、root C、ss…

随记-点选验证码

文字验证码(点击文字) 模板匹配(从一张图片中寻找 icon),放弃,目前准确率不高,且处理过程复杂 灰度处理将 complete_image_path 截取并另存为 target_image_path, verify_image_path…

微信小程序云开发教程——墨刀原型工具入门(添加交互事件)

引言 作为一个小白,小北要怎么在短时间内快速学会微信小程序原型设计? “时间紧,任务重”,这意味着学习时必须把握微信小程序原型设计中的重点、难点,而非面面俱到。 要在短时间内理解、掌握一个工具的使用&#xf…

鬼屋游戏c++

c #include <iostream> #include <string> #include <vector> #include <cstdlib> // 用于随机数生成 #include <ctime> // 用于随机数种子using namespace std;// 定义房间结构体 struct Room {string description;bool hasKey;bool hasClue…

找不到xinput1_3.dll的解决方法分析,快速修复xinput1_3.dll攻略

当您收到电脑上出现xinput1_3.dll文件缺失的提示时&#xff0c;不必过于担心。这是一个常见的问题&#xff0c;通常涉及到 DLL 文件丢失&#xff0c;而这类问题的解决办法相对直接。今天&#xff0c;我们会探讨几种针对修复xinput1_3.dll文件丢失情况的有效方法。 一.xinput1_3…

UDP套接字使用connect函数

在Linux环境下&#xff0c;UDP套接字可以使用connect函数。虽然UDP是无连接的协议&#xff0c;但是使用connect函数可以为UDP套接字设置一个默认的目标地址。 这样做有几个好处&#xff1a; 减少发送数据时的参数&#xff1a;当你使用connect函数为UDP套接字设置了一个目标地址…

LeetCode 热题 100 | 图论(一)

目录 1 200. 岛屿数量 2 994. 腐烂的橘子 2.1 智障遍历法 2.2 仿层序遍历法 菜鸟做题&#xff0c;语言是 C 1 200. 岛屿数量 解题思路&#xff1a; 遍历二维数组&#xff0c;寻找 “1”&#xff08;若找到则岛屿数量 1&#xff09;寻找与当前 “1” 直接或间接连接在…

python语言1

一、pytho中的注释 1.1注释的理解 程序员在代码中对代码功能解释说明的标注性文字可以提高代码的可读性注释的内容将被python解释器忽略&#xff0c;不被计算机执行 1.2注释的分类 注释分为&#xff1a;单行注释、多行注释、中文声明注释 &#xff08;1&#xff09;单行注…