CSRF(跨站请求伪造)详解

目录

一、📖什么是CSRF

二、🔗漏洞利用过程

三、📑漏洞的前提条件

四、🔍常见漏洞发生位置

五、✅CSRF挖掘技巧

(一) 抓正常请求包进行初步判断

(二) Referer 绕过验证测试

(三) Token 缺失与二次验证缺失识别

六、⚠️漏洞危害

七、🔒CSRF漏洞防御


一、📖什么是CSRF

CSRF(Cross-Site Request Forgery)是指攻击者诱导用户在已登录某网站的情况下,执行非本意的操作(如转账、改密码等)。它依赖于用户已登录状态下浏览器自动携带 Cookie 的特性。

二、🔗漏洞利用过程

  1. 攻击者发现目标网站存在 CSRF 漏洞,关键操作接口未对请求来源进行身份校验。
  2. 攻击者构造包含恶意请求的 Payload(如自动提交的表单、恶意图片、JS 脚本等),并嵌入到钓鱼网页或第三方平台。
  3. 通过社交工程手段(如钓鱼邮件、社交消息、伪装广告等)引导用户点击该页面或链接。
  4. 用户在已登录目标网站(如银行)且持有有效 Cookie 的情况下访问该恶意页面,浏览器自动携带 Cookie 发起请求。
  5. 如果目标网站未对请求来源进行验证,则会误以为该请求是用户主动发起的。
  6. 请求被成功执行,导致敏感操作被触发(如转账、修改信息、授权操作等),用户在毫无察觉的情况下被攻击。

三、📑漏洞的前提条件

  1. ✅用户登录了目标网站,并且登录状态仍然有效(如 Cookie 未失效)
  2. ✅网站对关键操作的请求没有做身份校验
  3. ✅用户能被引诱点击恶意链接或访问恶意页面
  4. ✅网站使用 Cookie 认证,而非 Token认证方式

四、🔍常见漏洞发生位置

  • 修改用户信息:如邮箱、密码、绑定手机
  • 金融交易类接口:如转账、支付、充值
  • 内容发布/删除:如发帖、删除评论、点赞
  • 管理员操作接口:如添加用户、授权、配置

五、✅CSRF挖掘技巧

(一) 抓正常请求包进行初步判断

抓取关键操作(如POST)的正常请求包:

  • 缺少 Referer / Origin 字段
  • 且请求中无明显 CSRF Token 或防伪参数(如 _csrf, token, authenticity_token),
    👉 则接口极有可能存在 CSRF 漏洞

(二) Referer 绕过验证测试

请求中即使存在 Referer 字段,也可进行伪造测试:

  • 使用 Burp 修改 Referer 为第三方域名,或直接删除;
  • 若服务端仍返回 200 正常响应并执行业务操作,
    👉 基本可以确认该接口未校验请求来源,存在 CSRF 风险

(三) Token 缺失与二次验证缺失识别

在表单提交、按钮操作、GET 请求等处:

  • 若用户操作无 CSRF Token 校验机制
  • 未引入验证码 / 二次确认弹窗 / 图形验证等二次验证措施,
    👉 该接口高概率可被构造 CSRF Payload

六、⚠️漏洞危害

  • 被利用执行敏感操作(如转账、改密码)
  • 账户被篡改、信息泄露
  • 管理员权限被下发
  • 业务被滥用(如刷积分、批量点赞)
  • 信任损失、法律风险等内容

七、🔒CSRF漏洞防御

  • 添加验证码/密码
    • 打断请求的自动化流程,用户主动交互,防止CSRF自动执行敏感操作。
  • 双重Cookie验证
    • 通过比较Cookie和请求参数中的值,验证请求合法性。
  • 使用CSRF Token
    • Token是随机会话特定的,攻击者难以预测或伪造。
  • 检查Referer头
    • 通过验证请求来源,确保请求来自合法域名(参考同源策略)。
  • 使用SameSite Cookie属性
    • 限制Cookie在跨站请求中的发送,防止伪造请求。

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

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

相关文章

深入解析 Qwen3-Embedding 的模型融合技术:球面线性插值(Slerp)的应用

在深度学习领域,模型融合技术是一种强大的工具,用于提升模型的鲁棒性和泛化能力。通过结合多个模型的优势,可以减少单一模型的过拟合风险,并在多种任务中实现更优的性能表现。在 Qwen3-Embedding 的训练过程中,模型融合…

【在线五子棋对战】二、websocket 服务器搭建

文章目录 Ⅰ. WebSocket1、简介2、特点3、原理解析4、报文格式 Ⅱ. WebSocketpp1、认识2、常用接口3、websocketpp库搭建服务器搭建流程主体框架填充回调函数细节 4、编写 makefile 文件5、websocket客户端 Ⅰ. WebSocket 1、简介 WebSocket 是从 HTML5 开始支持的一种网页端…

针对异构数据的联邦学习

在联邦学习中,数据异构性是指不同客户端之间的数据分布差异,包括数据的特征空间、标签空间以及数据量等方面的差异。处理异构数据是联邦学习中的一个重要挑战,因为异构数据可能导致模型训练过程中的性能不稳定、收敛速度较慢,甚至…

【判断自整除数】2022-4-6

缘由是判断自整除数的,这个我的结果是正确的,但是提交就有运行错误是怎么回事啊-编程语言-CSDN问答 void 自整除数字() {//所谓的自整除数字就是该数字可以整除其每一个位上的数字。 //对一个整数n,如果其各个位数的数字相加得到的数m能整除n,则称n为自…

@Import原理与实战

文章目录 前言一、导入普通类二、导入ImportSelector实现类三、导入ImportBeanDefinitionRegistrar实现类四、Import注解的解析4.1、解析实现ImportSelector的候选bean4.2、解析实现ImportBeanDefinitionRegistrar的候选bean4.3、DeferredImportSelector的特殊处理 总结 前言 I…

day 18进行聚类,进而推断出每个簇的实际含义

浙大疏锦行 对聚类的结果根据具体的特征进行解释,进而推断出每个簇的实际含义 两种思路: 你最开始聚类的时候,就选择了你想最后用来确定簇含义的特征, 最开始用全部特征来聚类,把其余特征作为 x,聚类得到…

Java并发编程实战 Day 11:并发设计模式

【Java并发编程实战 Day 11】并发设计模式 开篇 这是"Java并发编程实战"系列的第11天,今天我们聚焦于并发设计模式。并发设计模式是解决多线程环境下常见问题的经典解决方案,它们不仅提供了优雅的设计思路,还能显著提升系统的性能…

iview组件库:当后台返回到的数据与使用官网组件指定的字段不匹配时,进行修改某个属性名再将response数据渲染到页面上的处理

1、需求导入 当存在前端需要的数据的字段渲染到表格或者是一些公共的表格组件展示数据时的某个字段名与后台返回的字段不一致时,那么需要前端进行稍加处理,而不能直接this.list res.data;这样数据是渲染不出来的。 2、后台返回的数据类型 Datalist(pn) …

Ubuntu下有关UDP网络通信的指令

1、查看防火墙状态: sudo ufw status # Ubuntu 2、 检查系统全局广播设置 # 查看是否忽略广播包(0表示接收,1表示忽略) sysctl net.ipv4.icmp_echo_ignore_broadcasts# 查看是否允许广播转发(1表示允许&#xff09…

vue3:十六、个人中心-修改密码

一、页面效果 页面展示当前用户名(只读),展示需要输入的当前密码,输入新的密码以及确认密码的提交表单 二、初始建立 1、建立密码修改页面 在个人中心文件夹中写入新页面UpdatepwdView.vue 2、新建路由 在路由页面中写入修改密码页面 3、新建菜单 在菜单布局菜单页面中写…

GitFlow 工作模式(详解)

今天再学项目的过程中遇到使用gitflow模式管理代码,因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存,无论是github还是gittee,都是一种基于git去保存代码的形式,这样保存代码…

【Vue3】(三)vue3中的pinia状态管理、组件通信

目录 一、vue3的pinia 二、【props】传参 三、【自定义事件】传参 四、【mitt】传参 五、【v-model】传参(平常基本不写) 六、【$attrs】传参 七、【$refs和$parent】传参 八、provide和inject 一、vue3的pinia 1、什么是pinia? pinia …

【DAY43】复习日

内容来自浙大疏锦行python打卡训练营 浙大疏锦行 作业: kaggle找到一个图像数据集,用cnn网络进行训练并且用grad-cam做可视化 进阶:并拆分成多个文件

xtp+ctp 交易系统接口简介

CTP(上海期货交易所综合交易平台)和 XTP(中泰证券极速交易平台)是中国金融市场中两个重要的证券期货交易系统,它们在定位、架构和应用场景上有显著区别: 1. 开发主体与服务领域 维度CTPXTP开发公司上海期货…

阿里云Alibaba Cloud安装Docker与Docker compose【图文教程】

个人记录 进入控制台,找到定时与自动化任务 进入‘安装/卸载扩展程序’ 点击‘安装扩展程序’ 选择docker社区版,点击下一步与确定,等待一会 安装成功 查询版本 查询docker sudo docker version查询docker compose sudo docker compo…

非Root用户启动SSH服务经验小结

各位看官,小子我先问个问题:是不是经常在容器里想开个SSH,却发现自己不是root,处处碰壁?这是常态。多数容器镜像精简到连SSH服务都没有,就算有,咱们普通用户也没权限启动它。 今天小子就介绍一…

Windows开机自动启动中间件

WinSW(Windows Service Wrapper 是一个开源的 Windows 服务包装器,它可以帮助你将应用程序打包成系统服务,并实现开机自启动的功能。 一、下载 WinSW 下载 WinSW-x64.exe v2.12.0 (⬇️ 更多版本下载) 和 sample-minimal.xml 二、配置 WinS…

【CATIA的二次开发23】抽象对象Document涉及文档激活控制的方法

在CATIA VBA开发中,Document对象是最核心、最基础的对象之一。它代表了当前在CATIA会话中打开的一个文档(文件)。 几乎所有与文件操作、模型访问相关的操作都始于获取一个Document对象。Document对象包含多种方法和属性,以下介绍Document对象方法和属性 一、Document对象方…

基于多维视角的大模型提升认知医疗过程层次激励编程分析

系统架构设计 #mermaid-svg-k3W5lvie1sP3T956 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-k3W5lvie1sP3T956 .error-icon{fill:#552222;}#mermaid-svg-k3W5lvie1sP3T956 .error-text{fill:#552222;stroke:#55222…

【评测】Qwen3-Embedding模型初体验

回到目录 【评测】Qwen3-Embedding模型初体验 模型的介绍页面 0.6B运行配置:笔记本i5-8265U,16G内存,无GPU核显运行,win10操作系统 8B运行配置:AMD8700G,64G内存,4090D 24G显存,ub…