RATKing:有遠端存取木馬的新活動

XNUMX 月底,我們發現了一場分發遠端存取木馬 (RAT) 惡意軟體的活動,該程式允許攻擊者遠端控制受感染的系統。

我們檢查的組的特點是它沒有選擇任何特定的 RAT 家族進行感染。在該活動的攻擊中發現了多個特洛伊木馬程式(全部屬於公共領域)。憑藉這一特徵,這種分組讓我們想起了鼠王,一種由尾巴纏繞在一起的囓齒動物組成的神話動物。

RATKing:有遠端存取木馬的新活動
原文摘自 K. N. Rossikov 的專著《小鼠和類小鼠囓齒動物,在經濟方面最重要》(1908)

為了紀念這種生物,我們將我們正在考慮的團隊命名為「RATKing」。在這篇文章中,我們將詳細介紹攻擊者如何實施攻擊、他們使用了哪些工具,並分享我們對活動歸因的想法。

攻擊進展

該活動中的所有攻擊都是根據以下演算法進行的:

  1. 用戶收到一封釣魚電子郵件,其中包含 Google 雲端硬碟的連結。
  2. 使用該鏈接,受害者下載了一個惡意 VBS 腳本,該腳本指定了一個 DLL 庫以將最終有效負載加載到 Windows 註冊表中,並啟動 PowerShell 來執行它。
  3. DLL 庫將最終的有效負載(實際上是攻擊者使用的 RAT 之一)注入到系統進程中,並在自動運行中註冊 VBS 腳本,以便在受感染的電腦中站穩腳跟。
  4. 最終的有效負載在系統進程中執行,使攻擊者能夠控制受感染的電腦。

它可以示意性地表示如下:

RATKing:有遠端存取木馬的新活動

接下來,我們將重點放在前三個階段,因為我們對惡意軟體傳遞機制感興趣。我們不會詳細描述惡意軟體本身的運作機制。它們被廣泛使用——或者在專門的論壇上出售,甚至作為開源專案分發——因此並不是 RATKing 組織獨有的。

攻擊階段分析

第 1 階段. 網路釣魚電子郵件

攻擊始於受害者收到一封惡意電子郵件(攻擊者使用不同的文字範本;下面的螢幕截圖顯示了其中一個範例)。該訊息包含指向合法存儲庫的鏈接 drive.google.com,據稱這導致了 PDF 格式的文檔下載頁面。

RATKing:有遠端存取木馬的新活動
網路釣魚電子郵件範例

然而事實上,載入的根本不是PDF文檔,而是VBS腳本。

當您單擊上面螢幕截圖中電子郵件中的連結時,會出現一個名為 Cargo Flight Details.vbs。在這種情況下,攻擊者甚至沒有嘗試將該文件偽裝成合法文件。

同時,作為該活動的一部分,我們發現了一個名為 Cargo Trip Detail.pdf.vbs。它已經可以被視為合法的 PDF,因為 Windows 預設隱藏檔案副檔名。誠然,在這種情況下,其圖標仍然可能引起懷疑,因為它與 VBS 腳本相對應。

在此階段,受害者可以識別出欺騙行為:只需查看下載的檔案即可。然而,在此類網路釣魚活動中,攻擊者通常依賴不專心或倉促的用戶。

第二階段.VBS腳本運行

使用者可能因疏忽而開啟的VBS腳本在Windows註冊表中註冊了一個DLL庫。該腳本被混淆了:其中的行以由任意字元分隔的位元組形式編寫。

RATKing:有遠端存取木馬的新活動
混淆腳本的範例

反混淆演算法非常簡單:從混淆字串中排除每三個字符,然後將結果從 base16 解碼為原始字串。例如,從值 57Q53s63t72s69J70r74e2El53v68m65j6CH6Ct (在上面的螢幕截圖中突出顯示)結果行是 WScript.Shell.

為了對字串進行反混淆,我們使用了 Python 函數:

def decode_str(data_enc):   
    return binascii.unhexlify(''.join([data_enc[i:i+2] for i in range(0, len(data_enc), 3)]))

下面的第 9-10 行,我們突出顯示了反混淆後產生 DLL 檔案的值。下一階段使用PowerShell啟動的正是他。

RATKing:有遠端存取木馬的新活動
帶有混淆 DLL 的字串

VBS 腳本中的每個函數都是在字串被反混淆時執行的。

運行腳本後,函數被調用 wscript.sleep - 在它的幫助下執行了延遲執行。

接下來,該腳本與 Windows 註冊表一起工作。他為此使用了 WMI 技術。在它的幫助下,建立了一個唯一的金鑰,並將可執行檔的主體寫入其參數。使用以下命令透過 WMI 存取註冊表:

GetObject(winmgmts {impersonationLevel=impersonate}!\.rootdefault:StdRegProv)

RATKing:有遠端存取木馬的新活動
由 VBS 腳本在登錄中建立的條目

第 3 階段:使用 DLL

在第三階段,惡意DLL下載最終的有效負載,將其註入到系統進程中,並確保VBS腳本在使用者登入系統時自動啟動。

透過 PowerShell 運行

該 DLL 是在 PowerShell 中使用以下命令執行的:

[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0

該命令執行了以下操作:

  • 收到帶有名稱的註冊表值數據 rnd_value_name — 該資料是在.Net平台上編寫的DLL檔;
  • 將生成的 .Net 模組載入到進程記憶體中 powershell.exe 使用該功能 [System.Threading.Thread]::GetDomain().Load() (Load()函數詳細說明 可在 Microsoft 網站上找到);
  • 執行該功能 GUyyvmzVhebFCw]::EhwwK() - DLL庫的執行從它開始 - 帶參數 vbsScriptPath, xorKey, vbsScriptName。 範圍 xorKey 儲存用於解密最終有效負載的金鑰和參數 vbsScriptPath и vbsScriptName 被傳輸以便在自動運行中註冊VBS腳本。

DLL函式庫的說明

在反編譯的形式中,載入程式如下所示:

RATKing:有遠端存取木馬的新活動
反編譯形式的載入器(DLL函式庫開始執行的函式以紅色底線表示)

引導程式受 .Net Reactor 保護器保護。 de4dot 實用程式在刪除此保護程式方面做得非常出色。

這個裝載機:

  • 將有效負載注入到系統進程中(在本例中是 svchost.exe);
  • 我新增了一個VBS腳本來自動運行。

有效負載注入

讓我們來看看 PowerShell 腳本呼叫的函數。

RATKing:有遠端存取木馬的新活動
PowerShell 腳本呼叫的函數

該函數執行了以下操作:

  • 解密了兩個資料集(array и array2 在螢幕截圖中)。它們最初使用 gzip 進行壓縮,並使用金鑰使用 XOR 演算法進行加密 xorKey;
  • 將資料複製到分配的記憶體區域。數據來自 array - 到所指向的記憶體區域 intPtr (payload pointer 在螢幕截圖中);數據來自 array2 - 到所指向的記憶體區域 intPtr2 (shellcode pointer 在螢幕截圖中);
  • 稱為函數 CallWindowProcA (описание 該功能可在微軟網站上找到) 具有以下參數(參數名稱如下所列,在螢幕截圖中它們的順序相同,但具有工作值):
    • lpPrevWndFunc — 指向資料的指針 array2;
    • hWnd — 指向包含可執行檔路徑的字串的指針 svchost.exe;
    • Msg — 指向資料的指針 array;
    • wParamlParam — 訊息參數(在本例中,這些參數未使用且值為 0);
  • 創建了一個文件 %AppData%MicrosoftWindowsStart MenuProgramsStartup<name>.url哪裡 <name> - 這些是參數的前 4 個字符 vbsScriptName (在螢幕截圖中,具有此操作的程式碼片段以命令開頭 File.Copy)。因此,當使用者登入系統時,惡意軟體會將 URL 檔案新增至自動執行檔案清單中,從而附加到受感染的電腦。 URL 檔案包含腳本的連結:

[InternetShortcut]
URL = file : ///<vbsScriptPath>

為了了解注入是如何進行的,我們解密了資料集 array и array2。為此,我們使用了以下 Python 函數:

def decrypt(data, key):
    return gzip.decompress(
        bytearray([data[i] ^ key[i % len(key)] for i in range(len(data))])[4:])
    

結果,我們發現:

  • array 是一個 PE 檔案 - 這是最終的有效負載;
  • array2 是執行注入所需的 shellcode。

來自數組的 Shellcode array2 作為函數值傳遞 lpPrevWndFunc 到函數 CallWindowProcA. lpPrevWndFunc — 回呼函數,其原型如下:

LRESULT WndFunc(
  HWND    hWnd,
  UINT    Msg,
  WPARAM  wParam,
  LPARAM  lParam
);

所以當你運行該函數時 CallWindowProcA 帶參數 hWnd, Msg, wParam, lParam 執行數組中的 shellcode array2 有參數 hWnd и Msg. hWnd 是一個指向包含可執行檔路徑的字串的指針 svchost.exeMsg — 指向最終有效負載的指標。

shellcode 接收的函數位址來自 kernel32.dll и ntdll32.dll 基於名稱中的哈希值並將最終的有效負載注入到進程記憶體中 svchost.exe使用 Process Hollowing 技術(您可以在此處閱讀更多相關資訊) 文章)。注入shellcode時:

  • 創建了一個進程 svchost.exe 使用該功能處於暫停狀態 CreateProcessW;
  • 然後將該部分的顯示隱藏在進程的位址空間中 svchost.exe 使用函數 NtUnmapViewOfSection。這樣,程式就釋放了原進程的記憶體 svchost.exe,以便為該位址處的有效負載分配記憶體;
  • 在進程位址空間中為有效負載分配的記憶體 svchost.exe 使用函數 VirtualAllocEx;

RATKing:有遠端存取木馬的新活動
注射過程開始

  • 將有效負載的內容寫入進程位址空間 svchost.exe 使用函數 WriteProcessMemory (如下面的螢幕截圖所示);
  • 恢復該過程 svchost.exe 使用函數 ResumeThread.

RATKing:有遠端存取木馬的新活動
完成註入過程

可下載的惡意軟體

由於所描述的操作,受感染的系統上安裝了多個 RAT 級惡意軟體之一。下表列出了攻擊中使用的惡意軟體,我們可以放心地將其歸因於一組攻擊者,因為樣本存取了相同的命令和控制伺服器。

惡意軟體的名稱

第一次見到

SHA-256

C&C

進行注射的過程

黑暗軌跡

16-04-2020

ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702

kimjoy007.dyndns[.]org:2017

SVCHOST

視差

24-04-2020

b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043

kimjoy007.dyndns[.]org:2019

SVCHOST

戰區

18-05-2020

3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3

kimjoy007.dyndns[.]org:9933

SVCHOST

網線

20-05-2020

6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d

kimjoy007.dyndns[.]org:2000

SVCHOST

使用相同控制伺服器的分散式惡意軟體範例

這裡有兩件事值得注意。

首先,攻擊者同時使用了多個不同的 RAT 系列這一事實。對於已知的網路組織來說,這種行為並不常見,這些組織通常使用與他們熟悉的大致相同的工具集。

其次,RATKing 使用的惡意軟體要么在專門的論壇上以較低的價格出售,甚至是一個開源專案。

本文末尾給出了該活動中使用的惡意軟體的更完整清單(附帶一個重要警告)。

關於團體

我們無法將所描述的惡意活動歸因於任何已知的攻擊者。目前,我們認為這些攻擊是由一個全新的組織發動的。正如我們在開頭所寫的,我們稱之為 RATKing。

為了創建 VBS 腳本,該小組可能使用了類似於該實用程式的工具 VBS加密器 來自開發商 NYAN-x-貓。該程式創建的腳本與攻擊者的腳本相似,表明了這一點。特別是,他們都:

  • 使用函數執行延遲執行 Sleep;
  • 使用WMI;
  • 將可執行檔的主體註冊為註冊表鍵參數;
  • 使用 PowerShell 在自己的位址空間中執行此檔案。

為了清楚起見,請比較一下從登錄機碼執行檔案的 PowerShell 命令,該檔案由使用 VBS-Crypter 建立的腳本使用:

((Get-ItemPropertyHKCU:SoftwareNYANxCAT).NYANxCAT);$text=-join$text[-1..-$text.Length];[AppDomain]::CurrentDomain.Load([Convert]::FromBase64String($text)).EntryPoint.Invoke($Null,$Null);

使用攻擊者腳本使用的類似命令:

[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0

請注意,攻擊者使用 NYAN-x-CAT 的另一個實用程式作為有效負載之一。 萊姆RAT.

C&C 伺服器的位址顯示了 RATKing 的另一個顯著特徵:該組織偏好動態 DNS 服務(請參閱 IoC 的表中的 C&C 清單)。

國際奧委會

下表包含最有可能歸因於所描述的活動的 VBS 腳本的完整清單。所有這些腳本都很相似,並且執行大致相同的操作序列。它們都將 RAT 類惡意軟體注入到受信任的 Windows 進程中。它們都具有使用動態 DNS 服務註冊的 C&C 位址。

但是,我們不能聲稱所有這些腳本都是由同一攻擊者分發的,但具有相同 C&C 地址的樣本除外(例如 kimjoy007.dyndns.org)。

惡意軟體的名稱

SHA-256

C&C

進行注射的過程

視差

b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043

kimjoy007.dyndns.org

SVCHOST

00edb8200dfeee3bdd0086c5e8e07c6056d322df913679a9f22a2b00b836fd72

Hope.doomdns.org

SVCHOST

504cbae901c4b3987aa9ba458a230944cb8bd96bbf778ceb54c773b781346146

kimjoy007.dyndns.org

SVCHOST

1487017e087b75ad930baa8b017e8388d1e99c75d26b5d1deec8b80e9333f189

kimjoy007.dyndns.org

SVCHOST

c4160ec3c8ad01539f1c16fb35ed9c8c5a53a8fda8877f0d5e044241ea805891

franco20.dvrdns.org

SVCHOST

515249d6813bb2dde1723d35ee8eb6eeb8775014ca629ede017c3d83a77634ce

kimjoy007.dyndns.org

SVCHOST

1b70f6fee760bcfe0c457f0a85ca451ed66e61f0e340d830f382c5d2f7ab803f

franco20.dvrdns.org

SVCHOST

b2bdffa5853f29c881d7d9bff91b640bc1c90e996f85406be3b36b2500f61aa1

Hope.doomdns.org

SVCHOST

c9745a8f33b3841fe7bfafd21ad4678d46fe6ea6125a8fedfcd2d5aee13f1601

kimjoy007.dyndns.org

SVCHOST

1dfc66968527fbd4c0df2ea34c577a7ce7a2ba9b54ba00be62120cc88035fa65

franco20.dvrdns.org

SVCHOST

c6c05f21e16e488eed3001d0d9dd9c49366779559ad77fcd233de15b1773c981

kimjoy007.dyndns.org

CMD

3b785cdcd69a96902ee62499c25138a70e81f14b6b989a2f81d82239a19a3aed

Hope.doomdns.org

SVCHOST

4d71ceb9d6c53ac356c0f5bdfd1a5b28981061be87e38e077ee3a419e4c476f9

2004para.ddns.net

SVCHOST

00185cc085f284ece264e3263c7771073a65783c250c5fd9afc7a85ed94acc77

Hope.doomdns.org

SVCHOST

0342107c0d2a069100e87ef5415e90fd86b1b1b1c975d0eb04ab1489e198fc78

franco20.dvrdns.org

SVCHOST

de33b7a7b059599dc62337f92ceba644ac7b09f60d06324ecf6177fff06b8d10

kimjoy007.dyndns.org

SVCHOST

80a8114d63606e225e620c64ad8e28c9996caaa9a9e87dd602c8f920c2197007

kimjoy007.dyndns.org

SVCHOST

acb157ba5a48631e1f9f269e6282f042666098614b66129224d213e27c1149bb

Hope.doomdns.org

CMD

bf608318018dc10016b438f851aab719ea0abe6afc166c8aea6b04f2320896d3

franco20.dvrdns.org

SVCHOST

4d0c9b8ad097d35b447d715a815c67ff3d78638b305776cde4d90bfdcb368e38

Hope.doomdns.org

SVCHOST

e7c676f5be41d49296454cd6e4280d89e37f506d84d57b22f0be0d87625568ba

kimjoy007.dyndns.org

SVCHOST

9375d54fcda9c7d65f861dfda698e25710fda75b5ebfc7a238599f4b0d34205f

franco20.dvrdns.org

SVCHOST

128367797fdf3c952831c2472f7a308f345ca04aa67b3f82b945cfea2ae11ce5

kimjoy007.dyndns.org

SVCHOST

09bd720880461cb6e996046c7d6a1c937aa1c99bd19582a562053782600da79d

Hope.doomdns.org

SVCHOST

0a176164d2e1d5e2288881cc2e2d88800801001d03caedd524db365513e11276

paradickhead.homeip.net

SVCHOST

0af5194950187fd7cbd75b1b39aab6e1e78dae7c216d08512755849c6a0d1cbe

Hope.doomdns.org

SVCHOST

戰區

3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3

kimjoy007.dyndns.org

SVCHOST

db0d5a67a0ced6b2de3ee7d7fc845a34b9d6ca608e5fead7f16c9a640fa659eb

kimjoy007.dyndns.org

SVCHOST

網線

6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d

kimjoy007.dyndns.org

SVCHOST

黑暗軌跡

ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702

kimjoy007.dyndns.org

SVCHOST

WSH大鼠

d410ced15c848825dcf75d30808cde7784e5b208f9a57b0896e828f890faea0e

anekesolution.linkpc.net

RegAsm

青檸

896604d27d88c75a475b28e88e54104e66f480bcab89cc75b6cdc6b29f8e438b

softmy.duckdns.org

RegAsm

類星鼠

bd1e29e9d17edbab41c3634649da5c5d20375f055ccf968c022811cd9624be57

darkhate-23030.portmap.io

RegAsm

12044aa527742282ad5154a4de24e55c9e1fae42ef844ed6f2f890296122153b

darkhate-23030.portmap.io

RegAsm

be93cc77d864dafd7d8c21317722879b65cfbb3297416bde6ca6edbfd8166572

darkhate-23030.portmap.io

RegAsm

933a136f8969707a84a61f711018cd21ee891d5793216e063ac961b5d165f6c0

darkhate-23030.portmap.io

RegAsm

71dea554d93728cce8074dbdb4f63ceb072d4bb644f0718420f780398dafd943

chrom1.myq-see.com

RegAsm

0d344e8d72d752c06dc6a7f3abf2ff7678925fde872756bf78713027e1e332d5

darkhate-23030.portmap.io

RegAsm

0ed7f282fd242c3f2de949650c9253373265e9152c034c7df3f5f91769c6a4eb

darkhate-23030.portmap.io

RegAsm

aabb6759ce408ebfa2cc57702b14adaec933d8e4821abceaef0c1af3263b1bfa

darkhate-23030.portmap.io

RegAsm

1699a37ddcf4769111daf33b7d313cf376f47e92f6b92b2119bd0c860539f745

darkhate-23030.portmap.io

RegAsm

3472597945f3bbf84e735a778fd75c57855bb86aca9b0a4d0e4049817b508c8c

darkhate-23030.portmap.io

RegAsm

809010d8823da84cdbb2c8e6b70be725a6023c381041ebda8b125d1a6a71e9b1

darkhate-23030.portmap.io

RegAsm

4217a2da69f663f1ab42ebac61978014ec4f562501efb2e040db7ebb223a7dff

darkhate-23030.portmap.io

RegAsm

08f34b3088af792a95c49bcb9aa016d4660609409663bf1b51f4c331b87bae00

darkhate-23030.portmap.io

RegAsm

79b4efcce84e9e7a2e85df7b0327406bee0b359ad1445b4f08e390309ea0c90d

darkhate-23030.portmap.io

RegAsm

12ea7ce04e0177a71a551e6d61e4a7916b1709729b2d3e9daf7b1bdd0785f63a

darkhate-23030.portmap.io

RegAsm

d7b8eb42ae35e9cc46744f1285557423f24666db1bde92bf7679f0ce7b389af9

darkhate-23030.portmap.io

RegAsm

def09b0fed3360c457257266cb851fffd8c844bc04a623c210a2efafdf000d5c

darkhate-23030.portmap.io

RegAsm

50119497c5f919a7e816a37178d28906fb3171b07fc869961ef92601ceca4c1c

darkhate-23030.portmap.io

RegAsm

ade5a2f25f603bf4502efa800d3cf5d19d1f0d69499b0f2e9ec7c85c6dd49621

darkhate-23030.portmap.io

RegAsm

189d5813c931889190881ee34749d390e3baa80b2c67b426b10b3666c3cc64b7

darkhate-23030.portmap.io

RegAsm

c3193dd67650723753289a4aebf97d4c72a1afe73c7135bee91c77bdf1517f21

darkhate-23030.portmap.io

RegAsm

a6f814f14698141753fc6fb7850ead9af2ebcb0e32ab99236a733ddb03b9eec2

darkhate-23030.portmap.io

RegAsm

a55116253624641544175a30c956dbd0638b714ff97b9de0e24145720dcfdf74

darkhate-23030.portmap.io

RegAsm

d6e0f0fb460d9108397850169112bd90a372f66d87b028e522184682a825d213

darkhate-23030.portmap.io

RegAsm

522ba6a242c35e2bf8303e99f03a85d867496bbb0572226e226af48cc1461a86

darkhate-23030.portmap.io

RegAsm

fabfdc209b02fe522f81356680db89f8861583da89984c20273904e0cf9f4a02

darkhate-23030.portmap.io

RegAsm

08ec13b7da6e0d645e4508b19ba616e4cf4e0421aa8e26ac7f69e13dc8796691

darkhate-23030.portmap.io

RegAsm

8433c75730578f963556ec99fbc8d97fa63a522cef71933f260f385c76a8ee8d

darkhate-23030.portmap.io

RegAsm

99f6bfd9edb9bf108b11c149dd59346484c7418fc4c455401c15c8ac74b70c74

darkhate-23030.portmap.io

RegAsm

d13520e48f0ff745e31a1dfd6f15ab56c9faecb51f3d5d3d87f6f2e1abe6b5cf

darkhate-23030.portmap.io

RegAsm

9e6978b16bd52fcd9c331839545c943adc87e0fbd7b3f947bab22ffdd309f747

darkhate-23030.portmap.io

RegAsm⁠

來源: www.habr.com

添加評論