该漏洞是由于javascript获取url的参数,没有经过任何过滤,直接当作a标签和img标签的href属性和src属性输出。
二、漏洞复现
1、需要开启会员空间功能(默认关闭),登录后台开启会员空间功能。
data:image/s3,"s3://crabby-images/16fac/16fac4cd6ba1f14b41c08483e5b94f5cc5464834" alt=""
2、漏洞出现的位置在/e/ViewImg/index.html,浏览代码,发现如下代码存在漏洞
data:image/s3,"s3://crabby-images/61101/61101a6edcc41610f8a23e2d086563f8613533a7" alt=""
分析代码:通过Request函数获取地址栏的url参数,并作为img和a标签的src属性和href属性,然后经过document.write输出到页面。
3、跟进Request函数
分析代码:通过window.location获取当前url地址,根据传入的url参数,获取当前参数的起始位置和结束位置。
例如,地址是:index.html?url=javascript:alert(document.cookie),经过Request函数处理就变成javascript:alert(document.cookie)
data:image/s3,"s3://crabby-images/de67a/de67aed3affeaf5a0ae5db9972187f6e620e605f" alt=""
4、url地址经过Request函数处理之后,然后把url地址中的参数和值部分直接拼接当作a标签的href属性的值和img标签的src标签的值。
data:image/s3,"s3://crabby-images/5d0f8/5d0f8424cec9e4e694d17b2758c3934c0fb30dea" alt=""
5、通过上面的分析,可以发现代码没有对url的参数做过滤就直接拼接成a和img标签的属性的值,因此可以构造payload:? ?url=javascript:alert(/xss/)
6、浏览器访问http://192.168.10.171/empirecms/e/ViewImg/index.html?url=javascript:alert(/xss/)
data:image/s3,"s3://crabby-images/1f1a5/1f1a509e68a356b8c905b3bee0f78494f17ee1e6" alt=""
7、点击图片便可触发
data:image/s3,"s3://crabby-images/d218a/d218a5428b84fc09ba4e7d5262508c7af469bcfc" alt=""
参考:https://www.freebuf.com/vuls/177969.html
data:image/s3,"s3://crabby-images/93a07/93a078c4cc800d84742f4c8394e7f3481efd77f3" alt="帝国CMS(EmpireCMS) v7.5 前台XSS漏洞分析"