WEB-RPO攻击
RPO攻击
RPO(Relative Path Overwrite) —— 相对路径覆盖,是一种新型攻击技术,主要是利用浏览器的一些特性和部分服务端的配置差异导致的漏洞,通过一些技巧,我们可以通过相对路径来引入其他的资源文件,以至于达成我们想要的目的。
RPO利用条件以及利用结果
RPO攻击依赖于
- 浏览器与服务器对于url地址解析反应的不同。这种反应的不同可以由 两者解析差异,WEB缓存技术和配置差异 造成
- 前端代码使用相对于本页目录的相对路径来加载css/js
../css/style.css
或./style.js
利用结果:
浏览器把服务器返回的其他文件当做css/js来解析。通常单单RPO是没有什么作用的,因为服务器不会有什么恶意的css/js存在。
但是配合上一些可以控制的文件(比如可以控制php页面返回自定义css代码,或js代码)。控制服务端使其返回恶意文件+RPO形成解析,导致了XSS,信息泄露等漏洞产生。
浏览器与服务端的差异
先了解关于服务端和客户端浏览器在解析和识别上的差异性,以Apache服务器和Nginx服务器为例。
ps.测试代码取自p00mj博客
服务器对于URL的解析
对于%2f的解析
对于Apache服务器:
访问http://localhost/RPO/index.php
,成功
data:image/s3,"s3://crabby-images/414de/414de849e553a44507e686017237e0623c828410" alt="1.png"
对于/
URL编码%2f
访问http://localhost/RPO%2findex.php
,失败
data:image/s3,"s3://crabby-images/9f7c8/9f7c879b8fb7fa26219bb0397d0cf632acb5e7f3" alt="2.png"
对于Nginx服务器:
访问http://localhost/RPO/index.php
,成功
data:image/s3,"s3://crabby-images/11c2e/11c2e19770cfb0bb775a077576b0213d654ab61c" alt="10.png"
访问http://localhost/RPO%2findex.php
,成功
data:image/s3,"s3://crabby-images/deaf4/deaf4ae6ae867fe18cdcebac69e02d03b909101b" alt="11.png"
所以
- Nginx web服务器是会对带有%2f的URL解析的
- Apache服务器时不能对带有%2f的URL进行解析的
对于后续无意义目录的解析
两种web服务器结果一致:
访问http://localhost/1.php
,成功
data:image/s3,"s3://crabby-images/69f16/69f16bf073221db0964a95b7b2503df8ec3580c1" alt="3.png"
访问http://localhost/1.php/abc/ced.js/style.css
,成功,并且返回时跟1.php一样的界面
data:image/s3,"s3://crabby-images/0c3d0/0c3d0eb78c24cd5a81a1756d059f0f7388105689" alt="5.png"
由此可知:
服务器在找到有内容的页面后,不会解析后续没有意义的目录
客户端浏览器对于URL的解析
由于需要通过服务器的返回才能判断浏览器对于URL编码的解析,此处使用Nginx服务器。
访问http://localhost/RPO/aa%2fbb/index.php
,css获取../style.css
data:image/s3,"s3://crabby-images/0d56f/0d56f672341fa3d3b84374e24666f92d17656fa6" alt="16.png"
浏览器请求的页面:http://localhost/RPO/aa%2fbb/index.php
浏览器”应该”请求的CSS:http://localhost/RPO/aa/index.php
浏览器实际请求的css:http://localhost/RPO/style.css
由此可知:
浏览器是不会识别%2f作为路径分割的
利用场景-pathinfho
- 服务端:能不能对带有%2f的URL解析的WEB服务器都行(此例子是apache服务器)
- 客户端:所以对于客户端也没有要求.
- css获取:通过相对路径获取(此例子中
href="./style.css"
)
之所以对于两种不同的服务器没有限定,因为实际上这种利用场景我们都是通过/去访问服务器
先来了解浏览器根据相对路径请求css原则
访问http://localhost/RPO/index.php/country/wei
data:image/s3,"s3://crabby-images/57f12/57f12d5d1862c057a3cdfad1fcbc60fd5c1c2565" alt="6.png"
访问http://localhost/RPO/index.php/country/wei/
data:image/s3,"s3://crabby-images/bfeee/bfeee7578a123c8be83030508e263b7e35ea1d27" alt="7.png"
可以知道浏览器是根据最后一个/作为当前目录,在通过相对路径知道css地址,再向服务端去请求该地址的CSS
所以访问http://localhost/RPO/index.php/country/wei/style.css
作为css
而通过之前对于后续无意义目录的例子,可以知道css的内容应该跟index.php的内容一致
data:image/s3,"s3://crabby-images/415ca/415cad12e5fafca1f334d9c2ed7e6417b3042b8f" alt="8.png"
所以,此处就形成了把php文件当做是静态文件解析
单单这种形式的漏洞,利用空间较少,你必须要能向index.php中嵌入css(如果是加载作为js的话,就是嵌入js代码)才行,除了对于IE9,IE10的也可以利用同域文件前端小姿势
pathinfo例子
此例子参考rpo二三事
由于我们需要能在index.php中写入css,构筑index.php代码,进入同目录下css(其内容不重要)1
2
3
4
5
6<html>
<link href="style.css" rel="stylesheet" />
echo htmlspecialchars($_SERVER['PHP_SELF']);
echo "<br><";
</html>
正常访问情况
data:image/s3,"s3://crabby-images/61466/6146654b9702bbee5dff66ccff48a8201eb2f046" alt="12.png"
访问http://localhost/index.php/payload/
data:image/s3,"s3://crabby-images/41e89/41e8973478ee0e6a6f07f204c6aac90ff750e21d" alt="13.png"
观察css内容,意料之中执行index.php页面代码
data:image/s3,"s3://crabby-images/7ec1d/7ec1d36de4f7897a073561a23c34b5bd3bcfa4ad" alt="14.png"
开始注入payload{}*{background-color:red}
data:image/s3,"s3://crabby-images/3958a/3958a87db62a535f327313ccebf93e6ecdf3beb2" alt="15.png"
其他css-payload 可以参考前端小姿势
利用场景- 基于%2f
- 服务器:要求可以解析URL编码的WEB服务器(此处以Nginx为例)
- 浏览器:不解析URL编码
- css获取:通过相对路径获取
场景假设:index.php利用相对路径../css/style.css
引用style.css。我们可以修改profile.php向其中注入css代码。1
2
3
4
5
6目录结构
--php -- index.php
| |
| -- profile.php
|
css -- style.css
访问:http://localhost/RPO/aa/php/profile.php/aa%2f..%2f../index.php
服务器视角:http://localhost/RPO/aa/php/profile.php/aa/../../index.php
即http://localhost/RPO/aa/php/index.php
浏览器视角:http://localhost/RPO/aa/php/profile.php/aa%2f..%2f../index.php
CSS视角:http://localhost/RPO/aa/php/profile.php/css/style.css
加上服务器对于后续无意义目录的解析
最终实际从服务端加载的CSS:http://localhost/RPO/aa/php/profile.php
data:image/s3,"s3://crabby-images/19bbc/19bbc303cf19b025563838d18e068f4fb3052695" alt="17.png"
所以,此处就形成了把不同目录下的php文件当做是静态文件解析
利用的性质是:客户端与服务器对于%2f解析的不同,以及服务器对于多余目录的无视
基于%2f的跨目录解析例子
直接上CTF题目吧
防护RPO
- 不使用相对路径,加载css/js : 最有效了
- 在php页面最开头,声明
<!DOCTYPE html>
,使用规范模式解析
细节请参考rpo二三事
关于WEB缓存的攻击
不细说了,原理类似,应用环境不同 戳这里
参考
1 | http://www.freebuf.com/articles/web/166731.html |