CSRF 攻击是什么?如何防范?

1. 什么是 CSRF 攻击

跨站请求伪造,利用用户在特定网站上的登录状态。诱导用户在不知情的情况下执行攻击者预定的一些操作。

简单来说,就是攻击者通过受害者浏览器发送一个恶意请求到已经登录的网站。由于浏览器会自动携带这个网站的 cookie 认证信息。网站误认为请求是用户自己发起的。从而执行恶意的操作。比如转账、修改密码、发布内容等。这个就是 CSRF 攻击。

2. 如何防范?

2.1 使用 token

在表单或 ajax 请求中加入一次性 token,服务器在接受请求后,除了验证 cookie 外,还会验证这个 token 是否有效和未被使用过。

2.2 验证 referer

服务端验证请求头中的 referer 字段,referer 字段代表请求发送的站点。

2.3 二次确认

对于敏感操作,要求用户二次确认。比如转账,可以让用户在转账前,再次输入密码或验证码确认。

2.4 使用安全矿建或库

像 VUE 或 React 等都是内置了防止这种攻击的机制。我们需要充分利用它的这个安全特性。

2.5 限制 API 访问接口

对于 API 接口使用 API 密钥,对请求进行一些合法性的管理,确保接口调用来至授权的这个地址。

相关推荐
riuphan3 分钟前
JavaScript 类型判断完全指南
前端·javascript
华普微HOPERF4 分钟前
LoRa模块,如何通过卫星通信补齐地面网络的覆盖盲区?
网络·嵌入式硬件·模块·卫星通信
Hilaku9 分钟前
前端工程师最终会变成 AI工程师?
前端·javascript·程序员
yeflx13 分钟前
Ubuntu22.04重装显卡驱动
前端·chrome
小二·21 分钟前
Prompt Engineering 高级技巧:CoT/ToT/ReAct 等进阶方法论实战
前端·react.js·prompt
chancygcx_22 分钟前
前端框架React day1--React入门
前端·react.js·前端框架
quan_泉36 分钟前
DIDCTF 取证初学者
java·服务器·前端
无风听海1 小时前
Promise 与 Async Await 深度解析
前端·javascript
牛奶1 小时前
AI 永远说好,于是我们只会说 yes
前端·aigc·ai编程
浩风祭月1 小时前
把前端项目的 CI 构建时间从 15 分钟压到了 2 分钟
前端·ai编程