目录
1、打redis
ssrfme靶场实战
data:image/s3,"s3://crabby-images/991fa/991fae8e354ab1f9c9fa21c1f86d9e208d1f0e32" alt=""
页面直接给出了代码,过滤了file: dict ,等等
但是下面我们看到只要有info就能打印phpinfo()
data:image/s3,"s3://crabby-images/bf15e/bf15eafac8844d71fbed8a07ccc9410fbac86b32" alt=""
通过phpinfo()打印的信息,发现有内网其他服务器的ip
直接访问
data:image/s3,"s3://crabby-images/211a9/211a94d9899422dd01b3c800d75bbbdb18c80a06" alt=""
发现确实访问到了,我们抓包探测一下它开放了哪些端口
data:image/s3,"s3://crabby-images/7c5cd/7c5cdba0213cc55447a0067d6cf6a73a4fb7136b" alt=""
发现它只开放了80端口
这个时候我们想,内网的服务器ip一般是连续的,所以我们试一下前面几个ip
data:image/s3,"s3://crabby-images/59cb2/59cb2439de91303a31645bb10d315332a02ed1b7" alt=""
访问172.19.0.2这个ip的时候,发现有回显,它说 go away ,叫我离开?我就不离开,它肯定有问题 ,探测它的端口
data:image/s3,"s3://crabby-images/c543c/c543c22bd4acbaae55cfadcfafd7f8d7a0a5d9b0" alt=""
6379 !! 嘿,找到了!开始打redis
我们要想写webshell必须得知道它的物理路径,这个时候我们猜,一般是/var/www/html
但是这题它就不是一般,/var/www/html权限不够,它有个子目录upload有写的权限
这个时候我们要用gopherus这个工具来生成payload
data:image/s3,"s3://crabby-images/dcfbe/dcfbec205a8964f301af9e6eccdee288dbeac7e4" alt=""
因为要放在url传入,所以要进行urlcode二次编码
data:image/s3,"s3://crabby-images/50e46/50e46b427f5617354f06a8a1731e35591259c015" alt=""
执行之后,直接读文件
data:image/s3,"s3://crabby-images/9e277/9e27773bd5b6c15a3b521955d260b31b44a26932" alt=""
2、打fastcgi
data:image/s3,"s3://crabby-images/be8f7/be8f70c2a85655802203214975b2221ccc60387c" alt=""
抓包探测端口
data:image/s3,"s3://crabby-images/27a0b/27a0b035e1a62c5467f49a55cdcab477e9cc9da8" alt=""
发现无法探测出9000端口
但是我们看它的response,发现它是nginx
data:image/s3,"s3://crabby-images/212b9/212b9f43cf58b4a9323f67461ce479a2d7821fb0" alt=""
所以我们判断它是默认的9000端口有打开
同样用gopherus工具生成payload
data:image/s3,"s3://crabby-images/0dd47/0dd47899452feb83ccae80fa752b8c708e68a83d" alt=""
将payload解码分析
我们可以看到它其实就是利用php-fpm未授权访问,修改auto_prepend_file和allow_url_include这两个参数
data:image/s3,"s3://crabby-images/243a1/243a13eb24f126076c082068646bc87726e9bf21" alt=""
3、SSRF绕过
1、点分隔符替换:用。可以替换. www。baidu。com
2、@符绕过 https://www.biadu.com@127.0.0.1
= https://127.0.0.1
3、ip地址转换为其他进制数
4、302重定向到部署的vps,再location跳转到内网
5、DNS重绑定
4、SSRF防御
1、白名单过滤,只允许访问信任的ip和rul地址
2、尽量避免使用用户提供的url地址
3、禁用高危协议,dict,gopher,file
4、禁止302跳转
5、限制请求的端口