0

0

前端安全_CSRF防护JavaScript实现

夢幻星辰

夢幻星辰

发布时间:2025-11-30 19:13:31

|

576人浏览过

|

来源于php中文网

原创

CSRF防护需前后端协同,前端可通过SameSite Cookie、自定义请求头、同步Token及双重Cookie提交等措施辅助防御,核心在于配合后端实现安全策略。

前端安全_csrf防护javascript实现

CSRF(Cross-Site Request Forgery,跨站请求伪造)是一种常见的前端安全漏洞,攻击者诱导用户在已登录的状态下执行非本意的操作。虽然主要防护应在后端实现,但前端可以通过一些手段配合提升安全性。以下是基于 JavaScript 的常见 CSRF 防护实践与实现方式。

理解CSRF攻击原理

CSRF 利用用户在目标网站的认证状态,通过第三方站点发起伪造请求。例如:用户登录了银行系统,未退出的情况下访问恶意网站,该网站自动提交一个转账请求到银行系统,而浏览器会自动携带用户的 Cookie,导致请求被合法执行。

关键点在于:攻击者无法获取用户的 Cookie,但可以利用浏览器自动携带 Cookie 的机制发起请求。

前端可参与的防护措施

虽然 CSRF 防护的核心逻辑通常由后端完成,前端仍可通过以下方式协助防御:

立即学习Java免费学习笔记(深入)”;

1. 使用 SameSite Cookie 属性(推荐)

设置 Cookie 的 SameSite 属性为 StrictLax,可有效阻止跨站请求携带 Cookie。

示例(由服务端设置):

Set-Cookie: session=abc123; Path=/; Secure; HttpOnly; SameSite=Lax

前端虽不能直接设置此属性,但应确保与后端协作启用该策略。

2. 添加自定义请求头(如 X-Requested-With)

前端在发送敏感请求时,添加自定义请求头(如 X-Requested-With: XMLHttpRequest),后端校验该头是否存在。

使用 fetch 示例:

fetch('/api/transfer', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-Requested-With': 'XMLHttpRequest'
  },
  body: JSON.stringify({ to: 'user2', amount: 100 })
})

后端需检查该头,若缺失则拒绝请求。注意:此方法依赖同源策略,防止第三方脚本伪造该头。

3. 同步 Token 模式(Synchronizer Token Pattern)

后端生成一次性 Token,嵌入页面(如隐藏字段或 meta 标签),前端在请求中携带该 Token,后端验证其有效性。

Shoping购物网源码
Shoping购物网源码

该系统采用多层模式开发,这个网站主要展示女装的经营,更易于网站的扩展和后期的维护,同时也根据常用的SQL注入手段做出相应的防御以提高网站的安全性,本网站实现了购物车,产品订单管理,产品展示,等等,后台实现了动态权限的管理,客户管理,订单管理以及商品管理等等,前台页面设计精致,后台便于操作等。实现了无限子类的添加,实现了动态权限的管理,支持一下一个人做的辛苦

下载

实现步骤:

  • 后端渲染页面时注入 Token:

  • JavaScript 读取并附加到请求头:
const token = document.querySelector('meta[name="csrf-token"]').getAttribute('content');

fetch('/api/delete', {
  method: 'DELETE',
  headers: {
    'X-CSRF-Token': token,
    'Content-Type': 'application/json'
  }
})

后端对比 Token 是否匹配,防止重放和伪造。

4. 双重 Cookie 提交(Double Submit Cookie)

前端在请求中额外添加一个与 Cookie 中相同的 Token 字段,后端比对两者是否一致。

流程:

  • 后端在 Set-Cookie 时写入 csrf-token=abc123
  • 前端读取该 Cookie(需非 HttpOnly),并在请求体或头中再次发送

示例(使用 axios):

// 假设从 Cookie 获取 token
const csrfToken = getCookie('csrf-token');

axios.post('/api/action', { 
  data: 'example', 
  csrfToken // 请求体中包含
});

后端验证请求中的 token 与 Cookie 中的一致性。此方法无需服务器存储 Token,适合分布式系统。

避免常见误区

前端不应单独依赖 Referer 或 Origin 头进行判断,这些信息可能被篡改或缺失。真正的验证必须由后端完成。

不要将敏感操作绑定在 GET 请求上,避免链接被恶意调用。

静态资源托管站点更需警惕,即使无登录态,若用户处于同一浏览器环境,仍可能受攻击影响。

基本上就这些。前端能做的有限,关键是与后端协同,确保 Token 机制或 SameSite 策略落地。安全是全链路的事,JavaScript 不是主角,但也不能缺席。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

553

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

731

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

990

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

656

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

551

2023.09.20

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

4

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
小皮面板使用视频教程
小皮面板使用视频教程

共30课时 | 20.3万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.5万人学习

Rust 教程
Rust 教程

共28课时 | 4.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号