04XSS攻击的主要途径
第一种:对普通的用户输入,页面原样内容输出。打开http://go.ent.163.com/goproducttest/test.jsp(限公司IP),输入:<script>alert(‘xss’)</script>,JS脚本顺利执行。当攻击者找到这种方法后,就可以传播这种链接格式的链接(http://go.ent.163.com/goproducttest/test.jsp?key=JSCODE)如:http://go.ent.163.com/goproducttest/test.jsp?key=<script>alert(‘xss’)</script>,并对JSCODE做适当伪装,如:http://go.ent.163.com/goproducttest/test.jsp?key=%3c%73%63%72%69%70%74%3e%61%6c%65%72%74%28%27%78%73%73%27%29%3c%2f%73%63%72%69%70%74%3e,当其它用户当点此链接的时候,JS就运行了,造成的后果会很严重,如跳去一个有木马的页面、取得登陆用户的COOKIE等。第二种:在代码区里有用户输入的内容。原则就是,代码区中,绝对不应含有用户输入的东西。第三种:允许用户输入HTML标签的页面。用户可以提交一些自定义的HTML代码,这种情况是最危险的。因为,IE浏览器默认采用的是UNICODE编码,HTML编码可以用&#ASCII方式来写,又可以使用”/”连接16进制字符串来写,使得过滤变得异常复杂,如下面的四个例子,都可以在IE中运行1,直接使用JS脚本。<imgsrc=”javascript:alert(‘xss’)”/>2,对JS脚本进行转码。<imgsrc=”javascript:alert(‘xss’)”/>3,利用标签的触发条件插入代码并进行转码。<imgοnerrοr=”alert(‘xss’)”/>4,使用16进制来写(可以在傲游中运行)<imgSTYLE=”background-image:/75/72/6c/28/6a/61/76/61/73/63/72/69/70/74/3a/61/6c/65/72/74/28/27/58/53/53/27/29/29″>以上写法等于<imgSTYLE=”background-image:url(javascript:alert(‘XSS’))”>
来自:浏览器、网络相关-前端安全和注入-XSS等