首页
社区
课程
招聘
[原创]蠕虫病毒伪装传播,根目录文件遭神秘删除
发表于: 2024-7-3 19:09 2213

[原创]蠕虫病毒伪装传播,根目录文件遭神秘删除

2024-7-3 19:09
2213

近期,火绒威胁情报中心监测到一款通过改名为USB Disk来欺骗用户执行的蠕虫病毒正在传播,火绒安全工程师第一时间提取样本进行分析。分析过程中发现该程序在后台自动感染每个插入的可移动磁盘,并将原文件移动到一个隐藏文件夹中。随后,程序创建一个名为“USB Disk.exe”的文件,诱导用户点击以执行病毒程序。同时,程序还会启动后门进程,试图控制用户主机成为自己的肉鸡。目前,火绒安全产品可对上述病毒进行拦截查杀,请广大用户及时更新病毒库以提高防御能力。

火绒6.0查杀图


样本执行流程图如下所示:

流程图


在此,火绒工程师提醒大家对来历不明的文件应保持警惕,同时安装可靠的安全软件保护设备免受恶意软件和病毒的侵害。目前,火绒6.0已正式上线,综合用户的实际场景、使用感受和建议等多个方面,在形式、功能和操作等方面均进行了改进与创新,升级反病毒引擎等核心技术,精细化病毒查杀设置,增加更多威胁检测点,为“杀、防、管、控”增强壁垒。欢迎大家前往火绒官方网站下载体验。


一、样本分析

分析得出该病毒通过多个模块协同工作,通过白加黑的手段,具备较强的隐蔽性。其包含U盘传播、虚拟机检测、自启动设置、文件管理和CMD后门等多种恶意行为。

其中白文件是wwntray.exe(第二启动器)、Transfer.exe(蠕虫启动器)、Permissions.exe(后门启动器),它们主要是通过调用dll导出函数的方式执行恶意代码。

样本USB Disk.exe在刚被制作出来时并不能完整运行,因为需要满足多种条件才可执行,所以需要通过transfer.exe启动蠕虫并感染第一个可移动磁盘,从而“帮助”它满足条件才可以真正开始传播。

传播的方式是将USB Disk.exe放入到可移动磁盘中的根目录下,同目录下其他六个文件放入到可移动磁盘的隐藏目录中。之后在其他主机上使用该可移动硬盘并运行USB Disk.exe时,总启动器USB Disk.exe就会执行同目录下病毒文件夹中的wwntray.exe实现从可移动磁盘逆感染主机的操作,此时被感染的主机就会在后台执行蠕虫模块和后门模块,使每一个插入该主机的可移动磁盘都会被感染,重复第一次transfer.exe完成的操作。


初始化

病毒在运行蠕虫模块和后门模块前会进行一系列检查、持久化设置、删除部分文件等操作。

样本会在感染U盘时,将程序改名为USB Disk.exe,以诱导用户点击并执行。所以当USB Disk.exe程序在用户的U盘中出现时,意味着该U盘可能已被该病毒感染。


USB Disk.exe

该程序首先通过GetModuleFileName检查当前目录是否为盘符的根目录,如果不是,则结束运行。

随后,通过CreateProcess启动explorer.exe,参数为藏有U盘原文件的目录,此操作的主要目的是打开并展示受害者U盘中的原始文件,从而试图让受害者误以为自己仅仅是打开了USB Disk文件夹而不是病毒。

打开原始文件目录

U盘中原始文件目录


接着通过传入字符串参数"(C:)"来寻找磁盘根目录窗口并发送关闭窗口指令,目的是为了让受害者感受到打开的就是一个普通的文件夹。

关闭磁盘根目录窗口


并通过OpenEvent参数ConfigurantionDebug4防止程序多开wwnotray.exe,随后执行wwnotray.exe,参数为-debug。

执行wwnotray.exe


wwnotray.exe

wwnotray.exe加载wweb32.dll并执行该dll导出表中的ShowModalWordWebWEx函数,该函数包括持久化操作、执行蠕虫和后门模块等功能。

执行ShowModalWordWebWEx函数


程序首先通过CreateEvent检测事件是否已经存在来防止多开。

防止多开


动态获取函数地址:

动态获取函数地址


动态获取函数地址方法如下,主要原理是通过比对函数名Hash值来获取函数地址。

获取Windows API函数地址函数


其执行时会判断参数是否为-debug,以及路径中是否包含$WinUpdate,否则直接结束进程。

判断逻辑

随后样本开始删除文件C:\users\Public\GBPRSMBAL\WaveEditor.exe和C:\users\Public\GBPRSMBAL\WaveeditNero.exe,根据相关样本推测,这可能是老版本病毒文件名,进行清除。

删除文件

删除路径列表


还会删除目录,推测可能也是清除老版本的操作。

删除目录

删除目录列表


删除目录的操作是通过cmd命令加上参数/c rd/s/q来完成的。

CMD实现删除


通过reg.exe add设置注册表实现蠕虫模块和后门模块的自启动。

其中设置蠕虫模块为自启动的参数为add HKCU\Software\Microsoft\Windows\CurrentVersion\Run /v "Microsoft Usb" /d "C:\Users\Public\GBPAGVMCZ\Transfer.exe -Install" /f

设置自启动


创建存放病毒文件的文件夹"C:\Users\Public\GBPUXQLQU",并设置为隐藏文件和系统文件。

创建病毒文件夹


并把病毒文件复制到该文件夹中,附加参数执行,用于执行蠕虫和后门模块。

复制后执行蠕虫和后门模块


蠕虫模块

该模块的主要功能是将病毒文件复制到可移动磁盘中,并将可移动磁盘中的文件移动到隐藏文件夹中。最终,它会遍历D盘到L盘中的所有可移动磁盘。

下图是感染后U盘文件结构,可以看出除USB Disk以外均被隐藏。

U盘根目录


Transfer.exe加载drivespan.dll并执行函数run执行蠕虫函数。

执行蠕虫函数


创建事件drivespan4_以防程序多开。

创建事件


该模块也会动态获取函数地址并填充结构体。

动态获取函数地址


判断参数是否为Install、判断是否已经有事件防止双开、判断当前盘符是不是可移动磁盘,满足以上所有条件才会开始传播,最后会遍历D盘到L盘中所有可移动磁盘。

遍历传播逻辑


获取USB Disk名,如果有剩余空间就会填入剩余空间(GB为单位)

获取USB Disk名字


之后判断是否需要更新,接着创建一个没有名称的文件夹,并将其设置为隐藏和系统文件。需要注意的是,由于该程序会删除U盘根目录下的exe文件,因此这些文件将永久丢失。

创建文件夹并设置


样本会把所有病毒文件复制到可移动盘中,然后将DAQDeviceControl.exe复制到U盘并重命名为USB Disk.exe,同时修改该文件的version字段为4,并进行标记。接着,将所有可移动盘中的内容移动到一个隐藏文件夹中,使受害者只能通过运行这个USB Disk.exe文件来访问内容。

感染可移动盘符

后门模块

其主要功能包括搜集主机信息,文件管理和CMD远程执行以及循环发送心跳包以保持连接。该后门功能虽然较少,但是控制端可以通过CMD远程执行任意命令来完全控制被植入后门的主机。

Permission.exe加载RBGUIFramework.dll 并执行函数MainExport执行后门函数。

执行后门函数


后门模块通过接收的远程服务器的控制码,执行相应的恶意操作。

接收远程服务器指令


第一个远程命令——搜集主机数据:包括获取计算机名、用户名和系统架构等,可能用于标记受害者。

搜集主机数据


第二个命令——创建绑定管道的cmd进程以便远程执行命令。

创建管道


同时通过创建线程循环读取管道数据并发送到服务器,用于回显。

读取管道内容并发送


第三个命令——接收并通过CMD管道执行远程服务器的指令。

接收并执行CMD指令


第四个命令——创建文件并把句柄保存到结构体中。

创建文件


第五个命令——写文件,通过上面创建的句柄写入数据。

写入文件


第六个命令——删除文件:

删除文件


此外,后门模块会在开始接收指令前会创建线程,循环发送心跳包,用于检测客户端是否存活,以保持长连接。

发送心跳包

虚拟机检测

USB Disk.exe还包含一个虚拟机检测函数,目前尚未发现调用该函数的地方。该函数通过获取资源编号103、105和106,主要是解密出检测虚拟机的vmdetect.exe和执行该exe的代码。

首先获取编号为103的资源,即vmdetect.exe,用于检测虚拟机环境。

创建vmdetect.exe


然后获取105号资源,这是mspdbst.dll,加上偏移0x206000返回。

获取mspdbst.dll


之后获取106号资源,这是被加密的真正调用vmdetect.exe的函数,会写入到mspdbst.dll偏移0x206000位置并执行,最终获取返回值,以此来判断是不是虚拟机。

获取106号资源


资源都是被加密的,会通过秘钥异或解密,具体解密如下。


解密函数


执行vmdetect.exe。

执行vmdetect.exe


最后会通过调用这段代码来执行vmdetect.exe之后获取返回值来判断是不是虚拟机。

执行vmdetect.exe代码

vmdetect.exe其中一个检测VirtualBox的原理如下,主要是通过动态链接库、设备、注册表来判断是不是VirtualBox。

检测虚拟机


二、附录

C&C:


HASH:


[培训]《安卓高级研修班(网课)》月薪三万计划,掌握调试、分析还原ollvm、vmp的方法,定制art虚拟机自动化脱壳的方法

收藏
免费 0
支持
分享
最新回复 (0)
游客
登录 | 注册 方可回帖
返回
//