news 2026/4/15 18:19:44

客户端漏洞专题,核心讲解XSS和CSRF

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
客户端漏洞专题,核心讲解XSS和CSRF

今天咱们进入系列的第三期——客户端漏洞专题,核心讲解XSS(跨站脚本)和CSRF(跨站请求伪造)。这两类漏洞和之前的SQL注入不同,攻击目标不是服务器,而是用户的浏览器,利用的是浏览器对网站的信任机制,也是CTF Web模块中高频的基础题型,新手必须掌握!

话不多说,直接上干货!今天我们先拆原理,再讲实战,帮大家彻底分清XSS和CSRF的区别,轻松拿下这类题型的分数。

一、先分清:XSS和CSRF到底有啥不一样?

很多新手刚接触会把这两个漏洞搞混,先记住一个核心区别:

XSS:往页面里注入恶意脚本,让脚本在用户浏览器里执行,目的是偷取用户信息(比如Cookie、账号密码)。

CSRF:伪造用户的合法请求,让用户在不知情的情况下执行操作(比如转账、改密码),目的是利用用户权限做事。

用通俗的例子总结: XSS像在奶茶里加了泻药,让喝奶茶的人(用户)出问题; CSRF像“冒充你给商家发消息说‘把我的奶茶送给别人’”,利用你的身份(权限)做事。

二、XSS漏洞:跨站脚本的核心逻辑与实战

XSS的本质是:开发者没对用户输入的内容做过滤,导致恶意JavaScript脚本被嵌入到页面中,并且被浏览器执行。

1. 新手必懂的3种XSS类型

  • 存储型XSS:恶意脚本被存储到服务器数据库(比如评论区、个人资料),所有访问该页面的用户都会触发脚本(危害最大,CTF中最常考);

  • 反射型XSS:恶意脚本通过URL参数注入,只有点击了带有恶意参数的URL的用户才会触发(危害较小,常出现在搜索框、跳转页面);

  • DOM型XSS:通过修改页面的DOM结构触发,脚本不经过服务器,直接在客户端执行(相对少见,但需要掌握基础思路)。

2. 实战演练:存储型XSS拿Flag

以CTFshow新手场的存储型XSS题目为例,手把手教你解题:

题目场景
打开题目链接,是一个“留言板”页面,用户可以提交留言,页面会显示所有历史留言,Flag存储在管理员的Cookie中,我们需要通过XSS获取管理员的Cookie。

解题步骤
测试是否存在XSS:在留言框输入,提交后如果页面弹出“xss”弹窗,说明存在存储型XSS。

构造恶意脚本:核心是“偷取Cookie并发送到自己能访问的地方”,新手常用的payload(直接复制可用): 。

提交恶意留言:将构造好的payload输入留言框提交,等待管理员查看留言板(CTF题目中通常会模拟管理员访问,提交后直接触发)。

获取Flag:查看自己的服务器日志,会发现包含管理员Cookie的请求,其中就有Flag(格式:flag{xxx})。

三、CSRF漏洞:跨站请求伪造的核心逻辑与实战

CSRF的本质是:利用用户已登录的身份(浏览器保存的Cookie),伪造一个合法的请求,让用户在不知情的情况下执行特定操作。

1. CSRF成立的3个前提

用户已登录目标网站,浏览器保存了有效的Cookie。

攻击者能构造出合法的请求(知道请求的URL、参数、请求方法)。

用户在登录状态下访问了攻击者构造的恶意链接/页面。

2. 实战演练:CSRF伪造改密码请求

以修改用户密码”的CSRF题目为例,解题步骤:

题目场景
目标网站有“修改密码”功能,已知修改密码的请求是:http://题目地址/change.php?newpass=123456,请求方法为GET,我们需要构造CSRF页面,让登录的用户点击后自动修改密码为我们设定的值。

解题步骤
分析请求:通过Burp抓包确认修改密码的URL、参数(newpass)和请求方法(GET/POST)。

构造恶意页面:新建一个HTML文件,写入自动发送请求的代码(GET请求直接用img标签即可): < img src=“http://题目地址/change.php?newpass=hack123” style=“display:none”>。

诱导用户访问:将恶意HTML文件上传到自己的服务器,生成链接,诱导目标用户(已登录状态)点击。

验证结果:用户点击后,浏览器会自动发送修改密码的请求,密码被改为hack123,我们用新密码登录即可获取Flag。

四、新手避坑&学习建议

区分XSS和CSRF:记住“XSS偷信息,CSRF做操作”,不要混淆两者的攻击目标。

XSS payload灵活调整:如果基础payload被过滤,尝试替换标签(比如用代替script标签)。

CSRF重点看请求方法:GET请求构造简单(直接拼URL),POST请求需要构造表单自动提交。

推荐靶场:CTFshow新手场(XSS/CSRF专题)、DVWA(低/中难度模式)。

五、下期预告

今天我们搞定了XSS和CSRF这两个核心客户端漏洞,下期我们将进入第四期——文件上传/包含漏洞专题,这是Web模块中“突破服务器屏障”的关键漏洞,学会就能解决很多中难度题目。

如果今天的内容对你有帮助,别忘了点赞、在看,转发给一起学CTF的小伙伴~

网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我们和网安大厂360共同研发的的网安视频教程,内容涵盖了入门必备的操作系统、计算机网络和编程语言等初级知识,而且包含了中级的各种渗透技术,并且还有后期的CTF对抗、区块链安全等高阶技术。总共200多节视频,100多本网安电子书,最新学习路线图和工具安装包都有,不用担心学不全。

🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 17:04:11

PyTorch-CUDA-v2.9镜像能否运行LangChain应用

PyTorch-CUDA-v2.9镜像能否运行LangChain应用 在如今大模型应用爆发式增长的背景下&#xff0c;越来越多开发者尝试将语言模型集成到实际业务中。一个常见的技术组合是&#xff1a;使用 PyTorch-CUDA 镜像 作为底层运行环境&#xff0c;搭配 LangChain 构建复杂的 LLM 应用逻辑…

作者头像 李华
网站建设 2026/4/16 12:26:31

2025年智能运维平台选型指南:四大主流厂商深度解析与推荐

在数字化转型的深水区&#xff0c;企业IT架构日益复杂&#xff0c;混合云、云原生、信创化成为常态。传统的“烟囱式”运维工具堆叠已难以应对海量数据、复杂故障定位及业务连续性的高要求。智能运维平台&#xff0c;作为融合了大数据、人工智能、自动化与可观测性技术的下一代…

作者头像 李华
网站建设 2026/4/16 14:49:19

framebuffer双缓冲机制在PLC触摸屏中的实践

用双缓冲搞定工业触摸屏显示&#xff1a;从 framebuffer 到 PLC HMI 的实战之路在一条自动化生产线上&#xff0c;操作员轻触屏幕启动设备——但画面卡顿、文字闪烁&#xff0c;甚至出现“撕裂”现象。这种体验不仅让人焦虑&#xff0c;在某些关键场景下还可能引发误操作。这并…

作者头像 李华
网站建设 2026/4/16 14:31:44

PyTorch安装总失败?试试这个集成CUDA的稳定镜像版本

PyTorch安装总失败&#xff1f;试试这个集成CUDA的稳定镜像版本 在深度学习项目启动前&#xff0c;你是否也经历过这样的场景&#xff1a;满怀信心地打开终端准备训练模型&#xff0c;结果 torch.cuda.is_available() 却返回了 False&#xff1b;或者刚运行代码就抛出 ImportEr…

作者头像 李华
网站建设 2026/4/16 12:27:15

大模型学习避坑指南(初学者必看)

前言 近年来&#xff0c;大语言模型、多模态大模型等技术飞速发展&#xff0c;不仅重塑了人工智能领域的格局&#xff0c;也催生了大量学习需求。对于初学者而言&#xff0c;大模型领域涵盖机器学习、深度学习、自然语言处理、工程部署等多个交叉学科&#xff0c;知识体系庞大且…

作者头像 李华
网站建设 2026/4/15 2:22:11

Jupyter Notebook直连云GPU:PyTorch-CUDA-v2.9镜像使用教程

Jupyter Notebook直连云GPU&#xff1a;PyTorch-CUDA-v2.9镜像使用教程 在深度学习项目中&#xff0c;最让人头疼的往往不是模型设计&#xff0c;而是环境搭建——“在我机器上能跑”成了团队协作中的经典难题。更别提当你要用GPU加速训练时&#xff0c;CUDA驱动、cuDNN版本、P…

作者头像 李华