偷天换日——新型浏览器劫持木马“暗影鼠”分析

原文链接:
https://juejin.im/post/5aa119b26fb9a028e11f8881


腾讯电脑管家 · 2016/05/31 12:06

0x00 背景


近日哈勃分析系统截获了一批新型浏览器劫持木马 “暗影鼠”,该木马通常被打包在压缩包内伪装视频播放器通过网页进行传播。该木马的主要功能是对浏览器访问导航页的流量进行劫持,重定向到自己的推广页,非法获取推广利润。该木马最早出现是在今年的4月末,5月初开始小范围传播,但是从5月23开始突然爆发,高峰期全网中此木马用户数超过30W每日,保守估计近期木马作者以此获利总额有近百万元人民币。

传播趋势

0x02 木马介绍


“暗影鼠”启动后首先释放大批子文件,如下图所示

释放文件列表图

主要子文件功能:

  • cBLK.dll 木马核心功能模块,注入浏览器进程,流量劫持
  • newts.exe 64位系统下kill浏览器进程
  • undoing.exe 获取木马作者后台的推广列表
  • run.bat 清空浏览器缓存和临时文件
  • clk.ini 木马使用的配置文件

“暗影鼠”核心作恶流程

该木马在释放了一批子文件之后,枚举当前系统中的进程,与设定好的国内主流浏览器进程名进行对比,如果发现这些浏览器进程的存活,则杀掉相应进程,并且生成一个相应被感染的浏览器主进程的可执行文件。然后拉起这个被感染的假浏览器进程,假浏览器进程会加载之前释放的核心功能dll,然后再dll中hook关键系统函数,进行流量劫持。

0x02 主要功能模块技术分析


1.遍历进程杀浏览器进程

进程名比较代码段

枚举进程,寻找国内主流浏览器进程名。在此本文以chrome浏览器为例,对木马母体的TerminateProcess函数下断点,查看第一个参数。

结束chrome进程

查看句柄的含义

procxp中查看句柄含义

句柄对应的就是chrome进程

任务管理器中查看chrome的进程ID

可见木马母体中去杀的进程就是chrome.exe。

2.“狸猫换太子”假浏览器出场

杀掉真的chrome之后,木马母体在chrome.exe的同级目录下创建了下边两个文件。

释放被感染的chrome

上图中的exe就是一个被感染的chrome,会在启动时加载cBLK.dll,然后执行其内部包含的真正的chrome.exe。

假的chrome启动后,我们用spy++查看当前的浏览器窗口归属

spy++查看窗口的进程归属

假chrome进程树

0:000> ?9d4
Evaluate expression: 2516 = 000009d4
复制代码

0x9d4转成10进制就是2516

可以看到现在使用的chrome就是被感染的chrome。

3.cBLK目的何在

调试器附加假chrome

由上图可知假chrome加载了cBLK.dll,这个dll的主要功能就是hook系统关键函数。

主要Hook点

hook LoadLibraryExw

阻止加载列表

这个hook点的主要目的就是防止安全软件的浏览器安全模块加载。

hook WSASend发现对导航页的访问时

监控的导航页列表

构造302页面

发现对上述导航页的访问,则构造相应的302跳转页面。

hook WSARecv将对应的302页面返回,达到劫持目的

返回302页面

上图中的代码是在cBLK的WSARecv的hook函数中找到的,后边会调用真正的WSARecv,使得浏览器误以为接收到了302跳转页面,达到劫持目的。

4.其他技术点

启动被感染的浏览器进程,该样本还使用了监控浏览器桌面快捷方式点击的方法,非主要技术点在此不展开介绍。该样本也hook其他模块加载和网络发送接收函数,道理和上边说的一致,也不重复了。

哈勃分析系统目前对此样本的已经查杀。