CSRF详解

devtools/2024/11/13 13:30:21/

CSRF,全称是Cross-Site Request Forgery,即跨站请求伪造,也被称为“one click attack”或者session riding,是一种网络攻击方式。它允许攻击者诱导用户在已登录的Web应用程序上执行非预期的操作。
工作原理CSRF攻击通常涉及三个主体:受害者:已经登录到某个受信任的网站的用户。攻击者:试图利用受害者的身份在受信任的网站上执行恶意操作的人。受信任的网站:受害者当前登录并与之交互的网站。
CSRF攻击的典型流程如下:受害者登录到受信任的网站,并在其浏览器中保存了有效的会话cookie或认证令牌。受害者访问攻击者控制的恶意网站或点击了攻击者发送的恶意链接。恶意网站或链接包含了一个指向受信任网站的隐藏表单或JavaScript请求,该请求旨在利用受害者的会话cookie或认证令牌执行恶意操作。
受害者的浏览器自动发送包含会话cookie或认证令牌的请求到受信任的网站。受信任的网站验证会话cookie或认证令牌有效,并执行请求中的操作,尽管这些操作并非受害者本意。
防御措施为了防范CSRF攻击,可以采取以下措施:
使用CSRF令牌:为每个用户会话生成一个唯一的令牌,并在表单提交时验证该令牌。令牌应存储在服务器端,并在表单提交时与存储的令牌进行比较。
检查Referer头:虽然Referer头可以被伪造,但在大多数情况下,它提供了额外的安全检查层。可以配置服务器以拒绝不包含有效Referer头的请求。
使用双重提交Cookie:除了CSRF令牌外,还可以要求客户端在请求中提交一个与CSRF令牌匹配的Cookie值。实施同源策略:确保所有敏感操作都通过POST请求进行,并避免在GET请求中传递敏感信息。
限制会话有效期:缩短会话的有效期,以减少攻击者利用已登录会话的机会。通过实施这些防御措施,可以显著降低CSRF攻击的风险,并保护用户的敏感信息和操作安全。


http://www.ppmy.cn/devtools/133052.html

相关文章

Spring Security @PreAuthorize @PostAuthorize 权限控制

PreAuthorize : 在方法执行之前进行权限验证 PostAuthorize : 在方法执行之后进行权限验证 注解参数: hasRole,对应 public final boolean hasRole(String role) 方法,含义为必须含有某角色(非ROLE_开头),如有多个的…

vue,uniapp,微信小程序解决字符串中出现数字则修改数字样式,以及获取字符串中的数字

简单记录一下,最近遇到的一个新需求:后端返回的是非富文本,只是一串字符串,其中包含了文字和数字,前端需要将出现数字的地方将其加粗或者修改颜色等需求 设计思路:(简单做个记录方便以后理解&a…

mac-泛洪

泛洪攻击的类型 TCP SYN Flood: 攻击者向目标服务器发送大量的 TCP SYN 请求,但不完成握手过程。服务器为每个请求分配资源,最终可能耗尽其连接表,导致无法处理正常请求。 UDP Flood: 攻击者向目标发送大量的 UDP 数据…

spring AOP详解

文章目录 AOP1 环境准备1.1 工程及接口创建1.2 工程存在的问题1.2.1 问题1.2.2 解决思路 2 AOP面向切面编程2.1 AOP概述2.2 AOP原理分析 3 基于注解的AOP3.1 入门示例3.2 使用流程3.3 切入点表达式3.4 练习3.5 通知类型 AOP ​ AOP(Aspect Orient Programming&…

gitlab无法创建合并请求是所有分支都不显示

点击Merge Requests ------> New merge request 创建新的合并请求时,在Source branch和Target branch中一个分支都不显示 排查思路: 1.怀疑是权限问题。 发现只有我的一个账号出现,检查了账号的权限,尝试了master、develop角色…

图像手动标注-labelme+yolo格式导出

conda环境 运行以下命令来激活你的虚拟环境: conda activate labelme如果你没有创建 labelme 环境,首先需要创建一个环境并安装 labelme: conda create -n labelme python3.8 conda activate labelme conda install -c conda-forge labelm…

React Native的生命周期

React Native 组件的生命周期分为三个阶段:Mounting(挂载)、Updating(更新) 和 Unmounting(卸载)。每个阶段都会触发不同的生命周期方法。 下面是详细的生命周期解释,并通过一个项目…

关于Dell r730xd 老服务器的阵列卡 配置系统盘RAID 1

这里写自定义目录标题 关于Dell r730xd 老服务器的阵列卡 配置系统盘RAID 1操作步骤 关于Dell r730xd 老服务器的阵列卡 配置系统盘RAID 1 操作步骤 -开机后 按 Ctrl R 进入 RAID卡 配置界面,如下:-下面图片是 服务器中硬盘都已经准备好,并…