AutoIt是一个自动化的Windows界面交互的脚本语言,具有很高的灵活性和较低的学习曲线。由于AutoIt解释器本身属于合法程序,黑客可以把恶意代码藏在脚本文件中,从而灵活地创建恶意软件,在系统中没有独立进程存在,从而延长其存活周期。

以下是一个从国外流传进来的AutoIt木马样本,代表着此类木马家族典型的攻击手法。

样本信息

[AutoIt3.exe] 71D8F6D5DC35517275BC38EBCC815F9F
[googleupdate.a3x] E58C5E3F461089CA9688D3ACA204EA70

AutoIt3.exe是AutoIt脚本解释器,带有正规数字签名:

真正的病毒体是googleupdate.a3x

执行时依靠AutoIt3.exe调用googleupdate.a3x脚本。便会执行其中的恶意代码

如:

C:\Windows\system32\cmd.exe /c start skypee\autoit3.exe  autoit3executescript  skypee\googleupdate.a3x explorer "%cd%" & exit

在网上搜索C:\Google\ googleupdate.a3x,可以找到不少中招反馈。(此木马脚本被某些杀毒软件清理之后,没有清理干净残留文件,就会出现开机弹出这个错误框的现象)

代码分析

代码总共接近3300行,前1300行左右像是复制了一个通用代码。

里面有大量的常量的声明,封装了大量的WinAPI和GDI函数,并定义了大量的字符串、数组操作函数,甚至有限制鼠标活动范围的函数。

但这些预定义好的常量和函数后面用到的却很少。可能是出于作者习惯,每个脚本都要带上这段通用代码方便随时调用。

中间1582行是在拼一个很大的变量,内容是用base64编码过的

解开之后是一个不明身份的小帅哥照片。看照片信息是用三星Galaxy S4手机(GT-i9500)拍摄的,并经过PS处理,但没找到GPS左边或其他有用的信息,无法推断这人是谁……并且病毒执行后也没有调用这段数据,完全是一段垃圾数据。

只有最后的400行是真正的病毒代码。这部分代码主要做了四部分的工作:

一、检查自身运行环境

二、创建开机自启动

三、感染全部磁盘

四、驻留内存并与服务器通信实现远程控制

【检查自身运行环境】

1.检查自身是否存在于“c:\google”目录下,或目录中是否包含“skypee”字样,如果都没有则退出

2.通过创建互斥量“googleupdate”检查自身是否已经运行,如果已经运行则退出,不重复运行

3.检查自身是否处于被分析的环境中,如果认定自己处于被分析的环境则退出。检查逻辑如下表(字符串检测均不区分大小写):

4.检查自身是否在“c:\google”目录下,若不在,则将自身当前所在目录复制为“c:\google”,同时将目录设置为只读/系统/隐藏属性,启动新目录下的病毒脚本,并退出自身。

【创建开机自启动】

手法比较常规,就是写注册表的run项和向“启动”目录添加快捷方式:

1.注册表run项

2.向“启动”文件夹写入快捷方式

【感染全部磁盘】

1.检测注册表值,设置为不显示系统SuperHidden的文件:

2.遍历本地磁盘,在每个盘符下作如下操作:

a)在当前盘符根目录下新建名为“skypee”的目录。并将autoit3.exe和病毒脚本复制到该目录下。并将该目录属性设置为“只读/系统/隐藏”

b)遍历当前盘符根目录下所有文件夹,在每个文件夹下,创建一个与该文件夹同名的快捷方式文件。快捷方式指向a步骤中创建的病毒。并将快捷方式图标设置为文件夹图标

c)如果当前盘符属性为“removable”(最常见的是U盘),则会在盘符根目录下额外创建如下名称的快捷方式,指向a步骤中的病毒复制体,并将快捷方式图标设置为文件夹:

my games
my pictuers
my videos
hot
downloads
movies

【远程控制】

脚本在完成上述操作之后,会利用一个死循环代码常驻系统内存,并与远端服务器通信实现远程控制。

1.首先会循环尝试解析服务器列表中的所有域名,一旦解析成功则使用这个解析成功的域名作为连接地址,跳出这个尝试循环。不过脚本本身只在列表中填了一个域名:

2.进入常驻内存的远控死循环,连通远程服务器的95端口。成功后,会先将本地的机器名、用户名、所在国家、系统版本、当前存在的安全软件等信息发送出去。然后等待远端指令进行进一步操作。接受的指令如下:

由于脚本本身特性所致,很容易被编辑修改。所以分析人员将远控的控制服务器稍作修改,就在自己的机器中实现了对虚拟机内脚本的控制:

源链接

Hacking more

...