skills/malware/sandbox-evasion-implement/SKILL.md
沙箱逃逸与反分析技术实现。当需要让恶意载荷绕过自动化沙箱分析(AnyRun/Cuckoo/CAPE/Joe/Windows Defender Sandbox)时使用。覆盖环境检测、定时欺骗、用户交互检测、虚拟化检测等主流逃逸技术的实现方法
npx skillsauth add wgpsec/AboutSecurity sandbox-evasion-implementInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
定位:红队载荷投递前的反沙箱层设计。不是"分析沙箱逃逸",而是"实现沙箱逃逸"。
⛔ NEVER 只用单一逃逸手法 — 沙箱可以 hook 任何单一 API ⛔ ALWAYS 组合 3+ 种不同类别的检测,通过才执行 payload
逃逸层架构(洋葱模型):
┌─────────────────────────────────┐
│ Layer 1: 环境指纹(VM/沙箱检测)│
├─────────────────────────────────┤
│ Layer 2: 时间校验(Sleep 篡改) │
├─────────────────────────────────┤
│ Layer 3: 用户交互(非自动化) │
├─────────────────────────────────┤
│ Layer 4: 执行守卫(地理/域/进程)│
├─────────────────────────────────┤
│ Payload 解密执行 │
└─────────────────────────────────┘
所有 Layer 通过 → 才解密执行 payload
任一 Layer 失败 → 执行 decoy 行为或静默退出
检测项(选 3+ 组合):
├─ CPUID 指令 → Hypervisor Brand String
├─ 注册表 → HKLM\SYSTEM\CurrentControlSet\Enum\*VMware*
├─ MAC 地址前缀 → 00:0C:29(VMware) / 08:00:27(VBox)
├─ 设备驱动 → vmtoolsd.exe / VBoxService.exe
├─ BIOS 字符串 → SMBIOS 中的 "VBOX" / "VMware"
├─ 硬件 → CPU 核心数 < 2 / RAM < 4GB / 磁盘 < 60GB
└─ RDTSC 时间差 → VM Exit 导致延迟异常
已知沙箱进程名(存在即沙箱):
├─ cuckoomon.dll / agent.py / analyzer.py (Cuckoo)
├─ SbieDll.dll (Sandboxie)
├─ dbghelp.dll in unexpected path (AnyRun)
├─ frida-agent / xposed (Mobile sandbox)
└─ 用 CreateToolhelp32Snapshot 枚举进程列表
// 最简单有效:沙箱通常资源受限
MEMORYSTATUSEX mem;
mem.dwLength = sizeof(mem);
GlobalMemoryStatusEx(&mem);
if (mem.ullTotalPhys < 4LL * 1024 * 1024 * 1024) exit(0); // < 4GB
SYSTEM_INFO si;
GetSystemInfo(&si);
if (si.dwNumberOfProcessors < 2) exit(0); // < 2 CPU
原理:沙箱为加速分析会 patch Sleep() → 实际未等待
检测方式:
├─ Sleep 前后对比 GetTickCount → 差值远小于预期 = 被 hook
├─ NtDelayExecution + QueryPerformanceCounter 交叉验证
├─ RDTSC 指令直接读 CPU 时钟 → 不受 API hook 影响
└─ WaitForSingleObject(INVALID_HANDLE, timeout) 替代 Sleep
核心模式(不依赖 Sleep API):
1. 记录时间 T1 (QueryPerformanceCounter)
2. 执行一段计算密集型操作(如 SHA256 10万次)
3. 记录时间 T2
4. T2 - T1 应在合理范围内 → 否则被加速/虚拟化
原理:沙箱通常无真实用户操作
├─ 鼠标移动 → GetCursorPos 间隔采样,无变化 = 沙箱
├─ 点击计数 → GetAsyncKeyState 检测至少 N 次点击
├─ 窗口交互 → 要求用户点击对话框/输入内容才继续
├─ 文档宏 → 需要滚动到特定页/关闭后触发
└─ 浏览器 → 需要真实鼠标路径(非直线移动)
限制 payload 只在目标环境执行:
├─ 域名检测 → GetComputerNameEx() 匹配目标域
├─ 用户名检测 → 排除 "admin" / "sandbox" / "analyst"
├─ 地理位置 → IP 地理定位 API 或系统时区
├─ 已加入域 → 非 WORKGROUP = 企业环境
├─ 文件/注册表触发 → 特定文件存在才执行
└─ 环境变量 → 特定内部工具留下的 env var
所有检测通过后:
├─ 解密 payload(AES key 可从环境派生 → 沙箱无法解密)
├─ 内存加载(不落盘)
├─ 延迟执行(Sleep 真实 5-10 分钟后再连 C2)
└─ 清理检测痕迹
| 沙箱技术 | 对抗你的逃逸 | 你的应对 | |----------|-------------|---------| | Hook Sleep → 返回真实时间 | 打败简单 Sleep 检测 | 用 RDTSC / 计算密集型 | | 模拟鼠标移动 | 打败简单 GetCursorPos | 检测移动轨迹是否自然 | | 增加 CPU/RAM | 打败资源检测 | 组合多项,不依赖单一 | | 伪装注册表 | 隐藏 VM 指纹 | 用 CPUID / RDTSC 底层指令 | | 延长分析时间 | 等待 Sleep 结束 | Guardrails(域名/用户) |
成本效益比(最高 → 最低):
1. Guardrails(域/用户名)— 0 成本,直接过沙箱
2. 时间校验(RDTSC)— 底层,难 hook
3. 硬件资源(CPU+RAM+磁盘)— 简单有效
4. 用户交互(需配合社工载荷)
5. 虚拟化特征(最容易被对抗)
testing
Azure 云环境渗透测试总体方法论。当目标使用 Azure/Microsoft 365/Entra ID、发现 Azure 相关资产(Blob Storage/App Service/Azure VM/Azure Functions)、获取 Azure 凭据(Service Principal/Managed Identity/Access Token)、或需要对 Azure 环境进行安全评估时使用。提供从未授权枚举到 Entra ID 攻击、服务提权、Cloud-to-OnPrem 横向移动的全流程决策树。覆盖 35+ Azure 服务攻击面
tools
Mythic C2 操作方法论。当需要部署 Mythic、选择 Mythic Agent、安装 C2 Profile、配置 HTTP/DNS/WebSocket/SMB/TCP 通信、生成 payload、管理回连任务,或把 Mythic 作为跨平台 C2 框架用于授权红队演练时使用。覆盖 mythic-cli 安装、Agent/Profile 选择、SSL 证书配置、payload 构建和基础 OPSEC 判断
development
Docker 安全测试与容器渗透方法论。当需要评估 Docker 容器、Docker Daemon、Docker Registry、镜像层、构建产物或容器逃逸风险时使用。覆盖容器环境识别、特权容器逃逸、docker.sock/Remote API 利用、procfs/cgroup/capabilities 滥用、Docker 用户组提权、运行时/内核 CVE、Registry 枚举、镜像层 Secret 分析和构建上下文泄露。发现 Docker 容器环境、Registry 暴露、镜像凭据或容器配置错误时应使用此技能
development
使用 PadBuster 进行 Padding Oracle 攻击。当发现 Web 应用使用 CBC 模式加密且存在 Padding Oracle 漏洞时使用。PadBuster 可自动解密密文和伪造任意明文对应的合法密文,适用于加密 Cookie/Token/URL 参数。任何涉及 Padding Oracle 攻击、CBC 密文解密、Cookie 伪造的场景都应使用此技能