吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 11326|回复: 55
收起左侧

[PC样本分析] 一个botnet的样本分析

  [复制链接]
Assassin_ 发表于 2020-8-11 20:04
使用论坛附件上传样本压缩包时必须使用压缩密码保护,压缩密码:52pojie,否则会导致论坛被杀毒软件等误报,论坛有权随时删除相关附件和帖子!
病毒分析分区附件样本、网址谨慎下载点击,可能对计算机产生破坏,仅供安全人员在法律允许范围内研究,禁止非法用途!
禁止求非法渗透测试、非法网络攻击、获取隐私等违法内容,即使对方是非法内容,也应向警方求助!
本帖最后由 Assassin_ 于 2020-8-11 20:04 编辑

一个botnet的样本分析

前言

样本涉及的网络结构和设计模式比较陌生。对于我来说值得一看,可能有些地方理解不准确请海涵轻锤,但是深入研究,会发现这个样本越看越有意思,并且会有不少收获。

环境与工具

win 7 64位、IDA 7.0、exeinfo、OD

分析

其样本整体行为如下,中间有涉及hook和隐藏自身模块等操作还是可以学习的,其中隐藏模块自己实现了一下,但样本本身最有意思的地方还是网络通信。

未命名文件 (8).png

静态分析

样本基本信息

文件名称 crashreporter.exe
MD5 41a867c465464efa23b2451ae1367396
SHA256 6c362198a8879579c074ee8b0b14e712e059ff7f6037305e26f6d9ed47c6d39b
大小 116.00 KB
类型 Win32 EXE
作用(下载/释放) 释放执行
打包/编译语言 Microsoft Visual C++ ver. 8.0 / Visual Studio 2005 [ Debug:02 ]
编译/保存日期 2015:05:20 12:48:00+01:00
pdb C:\cc694wkw\x\4wiefw4\bv7mmx\67nqxrcs\g\e0q09q\2qnp\p4gxr\l9e7\xl4n6aq.pdb

1595831371946.png

静态拖入IDA,发现代码加密

1595831439327.png

查壳,发现无壳,不过代码应该还是被压缩了

1595831494489.png

动态分析

首先利用rdtsc进行反调试

1595837572275.png

1595837616018.png

调用VirtualProtectEx修改内存属性

1595837824580.png

代码解密

1595838661205.png

利用jmp指令跳转到解密代码

1595838747366.png

利用fs:[30]获取指定模块基址,通过获取Loadlibrary和Getprocaddress,然后利用GetProcAddress获取指定API

1595839242103.png

申请空间,并拷贝相应数据到该空间

1595839619876.png

申请空间并解压数据

1595839974227.png

解压之后发现该段数据为一个PE文件

1595840030186.png

接下来就是样本自身编写的一个PE Loader

修改自身PE内存属性,并将解密后的PE拷贝到原PE内存

1595840150657.png

重定位

1595840201648.png

获取API

1595840232458.png

修复内存属性

1595840324351.png

最后跳转到修改后的PE入口点

1595840472255.png

我们将其dump下来,此时就是恶意软件的本体了,对其进行分析

首先判断是否存在参数 /pid

1595851334299.png

对 ZwQueryVirtualMemory 进行Hook

1595851484636.png

1595851542076.png

我们查看该段代码

1595921814862.png

对其进行分析可以发现该段代码是对付沙箱的内存扫描,调用该函数会返回一段虚假的内存以欺骗沙箱

1595922030937.png

返回来,继续分析,通过申请空间,拷贝映像,并利用UnmapViewOfFile释放之前的映射的本体内存,这里可以自己写代码实现

1595908118772.png

发现找不到自身模块了

1596782677071.png

我们自己把代码抠出来,以后可以自己用

#include <iostream>
#include <Windows.h>

void My_UnmapViewOfFile()
{
    DWORD Imagebase;
    DWORD dwsize;
    DWORD lpaddr;
    char* result;
    LPVOID (*DwVirtualAlloc)(LPVOID lpAddress,SIZE_T dwSize,DWORD  flAllocationType,DWORD  flProtect);
    __asm
    {

        call $+5
        mov lpaddr,eax
        mov     eax, fs: [0x30]
        mov eax, [eax + 0x8]
        mov Imagebase, eax
        mov eax, [eax + 0x3c]
        add eax, Imagebase
        mov eax, [eax + 0x50]
        mov dwsize, eax
        mov eax, ds:VirtualAlloc
        mov DwVirtualAlloc, eax
    }

    if (UnmapViewOfFile((LPVOID)Imagebase))
    {
        if (DwVirtualAlloc((LPVOID)Imagebase, dwsize, 0x3000u, 0x40u) == (LPVOID)Imagebase)
        {
            __asm
            {
                mov ecx, dwsize
                mov esi, lpaddr
                mov edi, Imagebase
                rep movsb
            }
        }
    }
    return;
}

int main()
{
    DWORD Imagebase = 0;
    DWORD dwsize = 0;
    char* result;
    void (*lpAddress)(void);
    __asm
    {
        mov     eax, fs:[0x30]
        mov eax,[eax+0x8]
        mov Imagebase,eax
        mov eax, [eax+0x3c]
        add eax, Imagebase
        mov eax, [eax+0x50]
        mov dwsize, eax
    }
    result = (char*)VirtualAlloc(NULL, dwsize + 0x200, MEM_COMMIT | MEM_RESERVE, PAGE_EXECUTE_READWRITE);
    lpAddress = (void (*)(void))result;
    if (result)
    {
        memcpy(result, My_UnmapViewOfFile, 0x200u);
        memcpy(result + 0x200, (const void*)Imagebase, dwsize);
        lpAddress();
        VirtualFree(lpAddress, 0, 0x8000u);
        result = (char*)1;
    }
    ShellExecute(NULL, NULL, L"calc.exe", NULL, NULL, NULL);
}

设置Token

1595908241694.png

解密字符串并拼接

1595908446955.png

1595908824837.png

与当前目录进行比较,若存在指定目录则直接返回,否则,继续执行

1595915053277.png

查看当前是否位admin用户,如果不是则创建两个线程

1595918461482.png

1595918421586.png

这两个线程执行以下操作

线程1 :

以admin用户进行启动

1595918544377.png

线程2:

虚拟键盘输入空格

1595918589739.png

根据时间创建目录,并再次拷贝文件到该目录

1595919027617.png

1595919174504.png

创建名为syshost的服务,如果存在该服务,则先删除该服务,然后再次创建

1595919362270.png

尝试开启服务,如果开启失败,则不在利用服务进行自启动,而是通过注册表进行自启动

1595920912211.png

移动源文件到临时目录

1595921143418.png

最后清理文件,结束该进程

1595922176438.png

我们可以看到该进程再驻留时存在两种启动方式,一种是加参数 \service的服务启动,还有一种是直接注册表不加参数再指定目录直接启动的方式,二者无论以什么方式启动,其最终的行为是类似的。

我们首先分析直接启动的方式,经过之前的分析,我们定位到比较指定目录的地方,即上文中的下图,我们可以看到此时该函数直接返回

1595915053277.png

返回之后执行如下代码

1595924223256.png

我们没有参数,所以执行的是函数 00405BAC这个函数

进入该函数,首先判断进程类型

1595924952051.png

设置安全级别到最低,并且创建事件。其事件名分别为之前的解密字符串 Global/NitrGB 和 Local_NitrGB

1595925550969.png

1595925842447.png

设置错误处理函数,查看异常所在线程及其原因

1595926366081.png

之后遍历进程,排除自身对其他进程进行代码注入

1596095437147.png

注入采用CreateRemoteThread的方式

1596095506356.png

利用特殊指令检查虚拟机

1596095609673.png

1596095657285.png

更改并设置防火墙规则

1595926941065.png

解密内置域名

1595927665517.png

解密内置ip,总共有32个

1595929642086.png

获取卷GUID

1595989355074.png

根据卷GUID查询相关注册表

1595990305580.png

1595990533715.png

解码样本内置数据并利用WinAPI进行加密

1595996646364.png

1595994518850.png

将加密后的数据写入临时文件中
1595994622549.png

并复制其数据到注册表中

1595995155131.png

利用p2p进行网络连接

首先获取随机端口

1596077733958.png

进入主函数

开放tcp和udp的随机端口,并创建一个线程

1596078603478.png

[b]进入该线程,该线程功能为通过发送请求到其他bot,解析接收到的内容并更新自己的bot list或者C2或者ip list 或者发送内容到bot list中的任意bot,默认每5S发送一次,这段代码要好好看一下,如果能够理解,真的挺有意思的。

1597128609580.png

之后设置注册表,其值为随机端口进行加密后的值

1595993385001.png

1595993490351.png

其后再次查询并设置一系列注册表

1596003589273.png

开始进行网络连接, 利用C2进行数据的更新和恶意软件的分发

1596006426674.png

利用facebook.com和microsoft.com进行网络测试

1596005921648.png

1596004093065.png

创建4个线程

1596004727152.png

并4个线程中获取随机的域名迷惑分析者并通过对其进行DNS查询,将可以查询到的ip数据保存在一个列表中

1596004796612.png

对DNS查询的ip与之前获取facebook.com和microsoft.com的信息进行对比,确保不等于这两个ip的地址

1596007382749.png

然后连接硬编码域名,进行数据传输,获取当前精确时间

1596009475068.png

1596009488578.png

完成之后开始真正的C2连接

首先第一种就是硬编码的域名进行连接

1596022837230.png

第二种方式就是利用硬编码的Ip进行连接

1596022949009.png

如果C2连接成功之后,减慢bot之间的连接,变为每60S请求一次

1597128980536.png

如果以上两种连接不成功则加快bot之间的通信变为每一秒请求一次,利用第三种方法继续尝试C2的连接.


1597129011439.png

第三种方式,分为两部分拼接域名

第一部分

1596076202191.png

1596076289769.png

第二部分,获取后缀

1596075914498.png

1596076811277.png

最后进行数据的传输与交互

1596023006461.png

返回数据需要解密等复杂操作,故根据之前的分析,对其只能静态分析,不过我们可以看到后续的部分操作

如更新Botlist

1596077408606.png

代码执行

1596093186149.png

创建驱动文件等操作

1596096041577.png

结语

路漫漫其修远兮,吾将上下而求索。

免费评分

参与人数 33吾爱币 +34 热心值 +29 收起 理由
wzh06 + 1 + 1 表示很淦
heartbane + 1 看傻眼了
郎普 + 1 + 1 我很赞同!
不谙世事的骚年 + 1 + 1 我很赞同!
knifeyun + 1 + 1 谢谢@Thanks!
zhuobin_c + 1 热心回复!
qaz007 + 1 + 1 用心讨论,共获提升!
啦啦啦666 + 1 用心讨论,共获提升!
月六点年一倍 + 1 谢谢@Thanks!
idiots + 1 + 1 热心回复!
昨夜星辰恰似你 + 3 + 1 我很赞同!
gutian + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
Nyueyuan + 1 用心讨论,共获提升!
Psyber + 1 谢谢@Thanks!
poisonbcat + 1 + 1 谢谢@Thanks!
zsq + 1 + 1 谢谢@Thanks!
zhu111 + 1 谢谢@Thanks!
Yennfer_ + 1 + 1 谢谢@Thanks!
猛男z + 1 + 1 用心讨论,共获提升!
兰笙c + 1 + 1 用心讨论,共获提升!
fengbolee + 1 + 1 用心讨论,共获提升!
gaosld + 1 + 1 谢谢@Thanks!
黑界小子 + 1 + 1 我很赞同!
yixi + 1 + 1 谢谢@Thanks!
lookerJ + 1 + 1 我很赞同!
sunnylds7 + 1 + 1 热心回复!
chased + 1 + 1 谢谢@Thanks!
jy04468108 + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
女萝岩 + 1 + 1 我很赞同!
ghostsang + 1 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
qqww + 1 + 1 谢谢@Thanks!
Myst + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
禁闭岛 + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

lookerJ 发表于 2020-8-12 12:48
那张逻辑图总结的很棒。
CHILAS_LEE 发表于 2020-9-17 21:17
感谢楼主分享,我想请问一下楼主,我是在校的学生,实验室项目包含病毒分析方向,请问除了论坛上的帖子,还有什么地方可以学习相关技术吗,谢谢
arklearn 发表于 2020-8-11 22:47
感觉GPL2最无辜的,好好的版权协议,被利用了
boringdog 发表于 2020-8-11 23:54
看傻眼了,牛皮
 楼主| Assassin_ 发表于 2020-8-12 08:51
VS2019编译,代码编译选项需禁用GS安全检查。
danyang0511 发表于 2020-8-12 08:53
谢谢分享
chased 发表于 2020-8-12 09:54
感谢分享,很详细
sunnylds7 发表于 2020-8-12 10:03
感谢热心的分析
木子月 发表于 2020-8-12 12:38
楼主棒啊
guazi1990 发表于 2020-8-12 13:27
看着就很厉害(? ??_??)?
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-15 13:03

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表