掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
ThreadStackSpoofer是一種先進(jìn)的內(nèi)存規(guī)避技術(shù),它可以幫助廣大研究人員或紅/藍(lán)隊(duì)人員更好地隱藏已注入的Shellcode的內(nèi)存分配行為,以避免被掃描程序或分析工具所檢測(cè)到。

目前成都創(chuàng)新互聯(lián)公司已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站運(yùn)營(yíng)、企業(yè)網(wǎng)站設(shè)計(jì)、紅花崗網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
ThreadStackSpoofer是線程堆棧欺騙技術(shù)的一個(gè)示例實(shí)現(xiàn),旨在規(guī)避惡意軟件分析、反病毒產(chǎn)品和EDR在檢查的線程調(diào)用堆棧中查找Shellcode幀的引用。其思想是隱藏對(duì)線程調(diào)用堆棧上針對(duì)Shellcode的引用,從而偽裝包含了惡意代碼的內(nèi)存分配行為。
在該工具的幫助下,可以幫助現(xiàn)有的商業(yè)C2產(chǎn)品安全性有更好的提升,并協(xié)助紅隊(duì)研究人員開發(fā)出更好的安全產(chǎn)品/工具。
ThreadStackSpoofer的大致運(yùn)行機(jī)制和算法如下所示:
函數(shù)的返回地址會(huì)分散在線程的堆棧內(nèi)存區(qū)域周圍,由RBP/EBP寄存器存儲(chǔ)其指向。為了在堆棧上找到它們,我們需要首先收集幀指針,然后取消對(duì)它們的引用以進(jìn)行覆蓋:
- *(PULONG_PTR)(frameAddr + sizeof(void*)) = Fake_Return_Address;
廣大研究人員可以使用下列命令將該項(xiàng)目源碼克隆至本地:
- git clone https://github.com/mgeeky/ThreadStackSpoofer.git
使用樣例
- C:\> ThreadStackSpoofer.exe
其中:
欺騙Beacon的線程調(diào)用棧示例:
- PS D:\dev2\ThreadStackSpoofer> .\x64\Release\ThreadStackSpoofer.exe .\tests\beacon64.bin 1
- [.] Reading shellcode bytes...
- [.] Hooking kernel32!Sleep...
- [.] Injecting shellcode...
- [+] Shellcode is now running.
- [>] Original return address: 0x1926747bd51. Finishing call stack...
- ===> MySleep(5000)
- [<] Restoring original return address...
- [>] Original return address: 0x1926747bd51. Finishing call stack...
- ===> MySleep(5000)
- [<] Restoring original return address...
- [>] Original return address: 0x1926747bd51. Finishing call stack...
下面的例子中,演示了沒有執(zhí)行欺騙技術(shù)時(shí)的堆棧調(diào)用情況:
開啟線程堆棧欺騙之后的堆棧調(diào)用情況如下圖所示:
上述例子中,我們可以看到調(diào)用棧中最新的幀為MySleep回調(diào)。我們可以通過(guò)搜索規(guī)則查找調(diào)用堆棧未展開到系統(tǒng)庫(kù)中的線程入口點(diǎn):
- kernel32!BaseThreadInitThunk+0x14
- ntdll!RtlUserThreadStart+0x21
上圖所示為未修改的Total Commander x64線程。正如我們所看到的,它的調(diào)用堆棧在初始調(diào)用堆棧幀方面與我們自己的調(diào)用堆棧非常相似。
ThreadStackSpoofer:【GitHub傳送門】

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流