原文:
https://docs.google.com/presentation/d/1dYmdqZh-8JJ-FV20dtAz4VTLshDNBIhpGvfr4xv0OiA/mobilepresent?slide=id.g915c44e977_0_199
在vimeo的一次测试里,我发现了一个如下的数据包。
data:image/s3,"s3://crabby-images/439a1/439a167695fbe851e7200d62373a5b8579bc3947" alt=""
可以看到URI参数里存在两个参数,在segments里有对应的参数。
可以猜测一下拼接完的URL为api.vimeo.com/user/8089858/videos/111。如果我们修改video_id为../../../
data:image/s3,"s3://crabby-images/11aa5/11aa572dfb09499658e3e2fc38792ece74e63c03" alt=""
那么这个请求就会变为api.vimeo.com
data:image/s3,"s3://crabby-images/027c6/027c61a20d0c78354592316f51d7936746782a2a" alt=""
但是还是没有啥用啊。我们还是在api.vimeo.com里。
让任意URL跳转再次伟大
在2年的渗透过程中,我收集了很多URL跳转。我们将video_id修改为跳转的路径
data:image/s3,"s3://crabby-images/5e00c/5e00cf3e58467656486356ed1b03fdb226e09a60" alt=""
那么就会产生一个ssrf.
data:image/s3,"s3://crabby-images/6c42f/6c42f016e3a1651df366b1e767c6fdaab2e54b6a" alt=""
因为这个服务是Google云上的。所以可以请求元数据。
data:image/s3,"s3://crabby-images/aa1c1/aa1c14f8ade2d434b3ae4ecc13ed8d7c3476468c" alt=""
译者按:
作者找到了一个可控的path的SSRF,但是一般来讲没啥用,因为无法控制host部分。但是巧妙的通过了一个同域名任意URL跳转,重新组成了一个SSRF。
本文迁移自知识星球“火线Zone”