CSRF Token 原理

news2024/9/9 0:43:24

CSRF 攻击

在这里插入图片描述
CSRF 攻击成功的关键是,恶意网站让浏览器自动发起一个请求,这个请求会自动携带 cookie ,正常网站拿到 cookie 后会认为这是正常用户,就允许请求。

防范

如果在请求中加一个字段(CSRF Token),这个字段不会自动携带,正常网站就可以辨别,这个请求是不是由用户自己发起的了

  • 用户先发起一个请求给网站,网站提供用户两个字段:set_Cookie、CSRF_Token
    • 客户端拿到cookie值 会自动存储在浏览器的 cookie 中
    • 客户端拿到CSRF_Token 可以存储到 localstorage 中(服务端通常会保存这个字段在 session 中)
  • 用户再次发起请求,点击提交按钮,JS 逻辑将 CSRF_Token 加到请求头中,如:X-CSRF-Token:asfiksakjckkGkuvgsku(这个字段不会随请求自动携带)
    • 服务端验证 cookie 值是否正确
    • 服务端验证 CSRF_Token 是否正确

CSRF Token 生成库:csurf

// 1 导入 express
const express = require('express')
const cors = require("cors");  // 跨域解决库

// 引入用户密码
const userDataBase = require('./xxxxxx.js')

// 2 创建一个对象
const app = express();  

// --- token
const cookieParser = require("cookie-parser");  // 解析客户端发送过来的 Cookie 头部
const csrf = require("csurf");  
var bodyParser = require('body-parser')
// 使用 cookie-parser 中间件  

// 使用 csurf 中间件  
const csrfProtection = csrf({ cookie: true });  

app.use(cookieParser());  
app.use(csrfProtection);  


// ---解析post数据工具
// 使用 express.json() 中间件来解析 JSON 格式的请求体
app.use(express.json());


// ----

// -----跨域解决方案1  配置 CORS,允许来自 http://localhost:8094 的请求  
const corsOptions = {  
  origin: "http://localhost:8094",  
  credentials: true, // 允许携带 cookie  
};  
app.use(cors(corsOptions));  
// ------

// 3 获得 csrf token
app.get('/api/get-token', (req, res) => {
  // 跨域解决方案2 设置头
  // res.setHeader("Access-Control-Allow-Origin", "*")
  res.json({ csrfToken: req.csrfToken() }); 
})

// 验证 csrf token
app.post('/api/login', csrfProtection, (req, res) => {
  // 会验证cookie和x-xsrf-token(cookie需要cookieParser解析)
  console.log('POST请求成功,CSRF验证通过')
})

// 监听端口
app.listen(3000, () => {
  console.log('服务已启动,端口3000正在监听....')
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1958589.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++笔记之指针基础

函数重载:(C++特性) 定义: C++允许函数重名,但是参数列表要有区分 在相同的作用域定义同名的函数,但是它们的参数要有所区分,这样的多个函数构成重载关系 objdump -d test.exe >log.txt 将test.exe反汇编并将结果重定向到log.txt 文件中 ,然后在 log.txt中找到定…

学习网络安全 为什么Linux首择Kali Linux? 以及如何正确的使用Kali Linux

1.什么是kali linux? Kali Linux是一款基于Debian的Linux发行版,主要用于网络安全测试和渗透测试。它由全球顶尖的安全专家和黑客社区维护开发,提供了丰富的工具和资源,用于测试安全性、漏洞利用和渗透测试。此外,Kal…

MySQL 性能调优

文章目录 一. MySQL调优金字塔1. 架构调优2. MySQL调优3. 硬件和OS调优4. 小结 二. 查询性能调优三. 慢查询1. 概念2. 优化数据访问3. 请求了不需要数据,怎么做4. 是否在扫描额外的记录5. 慢查询相关配置 & 日志位置6. 小结 四. 查询优化器五. 实现调优手段 一.…

24、Python之面向对象:责任与自由,私有属性真的有必要吗

引言 前面我们进一步介绍了类定义中属性的使用,今天我们对中关于属性私有化的话题稍微展开聊一下,顺便稍微理解一下Python设计的相关理念。 访问级别 在其他编程语言中,比如Java,关于类中的属性和方法通过关键字定义明确的访问级…

1、仓颉工程基础操作 cjpm

文章目录 1. 仓颉工程创建方式2. cjpm2.1 init 初始化工程2.2 run 运行工程 1. 仓颉工程创建方式 使用 cangjie studio 通过cangjie studio 创建 使用vscode插件 通过 VSCode 命令面板创建仓颉工程通过可视化界面创建仓颉工程 cjpm 注:具体使用参考官方文档&#…

探索分布式光伏运维系统的组成 需要几步呢?

前言 随着光伏发电的不断发展,对于光伏发电监控系统的需求也日益迫切,“互联网”时代,“互联网”的理念已经转化为科技生产的动力,促进了产业的升级发展,本文结合“互联网”技术提出了一种针对分散光伏发电站运行数据…

浅谈Devops

1.什么是Devops DevopsDev(Development)Ops(Operation) DevOps(Development和Operations的混合词)是一种重视“软件开发人员(Dev)”和“IT运维技术人员(Ops)”…

asp.net mvc 三层架构开发商城系统需要前台页面代完善

一般会后端开发,都不太想写前台界面,这套系统做完本来想开源,需要前台界面,后台已开发,有需求的朋友,可以开发个前端界面完善一下,有的话可以私聊发给我啊

The Llama 3 Herd of Models 第6部分推理部分全文

第1,2,3部分 介绍,概览和预训练 第4部分 后训练 第5部分 结果 6 Inference 推理 我们研究了两种主要技术来提高Llama 3405b模型的推理效率:(1)管道并行化和(2)FP8量化。我们已经公开发布了FP8量化的实现。 6.1 Pipeline Parallelism 管道并行 当使用BF16数字表示模型参数时…

VirtualBox创建共享磁盘

VirtualBox创建共享磁盘 目录 VirtualBox创建共享磁盘1、划分共享磁盘1.1、【管理】->【工具】->【虚拟介质管理】1.2、【创建】->【VDI(VirtualBox 磁盘映像)】->【下一步】1.3、【预先分配全部空间】->【下一步】1.4、【分配大小】->…

5、springboot3 vue3开发平台-后端- satoken 整合

文章目录 1. 为什么使用sa-token2. 依赖导入jichu2.1 基础依赖引入2.2 redis整合2.3 redis 配置, 使redis能支持中文存储 3. 配置4. 配置使用4.1 权限加载接口实现, 登录实现4.2 配置全局过滤器4.3 登录异常处理 5. 登录测试6. 用户session的获取 1. 为什…

MySQL索引与存储引擎、事物

数据库索引 是一个排序的列表,存储着索引值和这个值所对应的物理地址 无须对整个表进行扫描,通过物理地址就可以找到所需数据 是表中一列或者若干列值排序的方法 需要额外的磁盘空间 类型 普通索引 最基本的索引类型,没有唯一性之类的限制 创…

图不连通怎么办?

目录 1.问题 2.连通的相关概念 3.解决方案 C语言示例实现: 1.问题 无论是图的深度还是广度遍历都是从图的某一条边往下走,那么被孤立的结点怎么被遍历到呢? 2.连通的相关概念 连通:如果从V到W存在一条(无向&#…

3D魔方游戏制作lua迷你世界

--3D魔方 --星空露珠工作室 --核心脚本来自负负 --1:xy 2:yx 3:xz 4:zx 5:yz 6:zy --4000,0-3 3995-0,3 local trn{ {{5,2},{3,1},{1,2},{1,3},{4,0},{2,2}}, {{3,0},{5,3},{1,3},{1,2},{2,3},{4,1}}, {{4,2},{2,1},{1,1},{1,0},{3,3},{5,1}}, {{2,0},{4,3},{1,0},{1,1},{5,0},…

Web3.js 4.x版本事件监听详解:从HTTP到WebSocket的迁移

项目场景 在一个使用以太坊区块链技术的项目中,需要监听智能合约的事件,以便在事件触发时能够及时响应。项目中使用了web3.js库的4.x版本,节点使用Geth启动,并通过HTTP与节点进行通信。 问题描述 合约DataStorage.sol文件已经定…

华为项目管理工具集

华为项目管理10大模板是一套被广泛认可和使用的项目管理工具集,它包含了在项目管理过程中常用的各种表格和文档模板。这些模板旨在帮助项目经理更有效地规划、执行和监控项目,确保项目的成功交付。 虽然具体的模板内容可能会有所不同,但根据…

51 单片机的Keil5软件

1. KEIL C51 软件获取 博主网盘下载:链接:https://pan.baidu.com/s/1YBfrRh2L7SIehS5xLQkAow?pwd4211 提取码:4211 也可以在 KEIL 的官网上下载:http:// https://www.keil.com/download/product/ 打开界面如下图所示&#xff1…

机器学习(二十三):决策树和决策树学习过程

一、决策树 下面是数据集,输入特征是耳朵形状、脸形状、是否有胡子,输出结果是是否为猫 下图是决策树,根据耳朵形状、脸形状、是否有胡子这几个特征,建立决策树,从根节点一步步预测结果。 上图中,每一个椭…

[硬件]—电感传感器

电感传感器 1.概述 工作基础:电磁感应,即利用线圈自感或互感的改变来实现非电量测量。工作原理: 被测物理量(非电量:位移、振动、流量);线圈自感系数L/互感系数M;电压或电流&#…

QT常用的控件(二)

QT的常用控件 一.按钮类控件1.1 Push Button代码示例: 带有图标的按钮代码示例: 带有快捷键的按钮代码示例: 按钮的重复触发 1.2 Radio Button代码示例: 选择性别代码示例: click, press, release, toggled 的区别代码示例: 单选框分组 1.3 Check Box代码示例: 获取复选按钮的取…