skills/threat-intel/threat-hunting-evasion/SKILL.md
威胁猎杀原理与规避方法论。理解蓝队如何主动猎杀(Hypothesis-driven / IOC-driven / Analytics-driven),红队如何设计行为使自己不被猎杀到。当需要评估自身操作是否可被威胁猎杀发现时使用
npx skillsauth add wgpsec/AboutSecurity threat-hunting-evasionInstall 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.
红队必须理解猎手的思维方式才能不被猎到
以下 reference 体量较大,不要在只需要通用猎杀方法论时预读;只有任务明确涉及规则拆解、EDR 逻辑或规避验证时再打开对应文件。
1. 假设驱动(Hypothesis-driven)
"如果 APT29 入侵我们,他们会用 PowerShell 下载器"
→ 搜索: EventID 4104 + "IEX" + "DownloadString"
2. IOC 驱动(IOC-driven)
"威胁情报显示这个 IP 是 C2"
→ 搜索: 所有连接到该 IP 的主机
3. 分析驱动(Analytics-driven)
"正常用户不会在凌晨 3 点执行 whoami"
→ 搜索: 异常时间 + 侦察命令组合
# Sigma 规则示例
# 1. 可疑 PowerShell 下载
title: Suspicious PowerShell Download
detection:
selection:
EventID: 4104
ScriptBlockText|contains:
- 'IEX'
- 'Invoke-Expression'
- 'DownloadString'
- 'Net.WebClient'
# 2. LSASS 访问
title: LSASS Memory Access
detection:
selection:
EventID: 10
TargetImage: 'C:\Windows\System32\lsass.exe'
GrantedAccess|contains:
- '0x1010'
- '0x1410'
# 3. 异常父子进程
title: Suspicious Parent-Child
detection:
selection:
ParentImage|endswith: '\outlook.exe'
Image|endswith:
- '\cmd.exe'
- '\powershell.exe'
- '\mshta.exe'
# 4. 枚举命令组合(5分钟内执行3+侦察命令)
title: Reconnaissance Commands
detection:
selection:
CommandLine|contains:
- 'whoami'
- 'net user'
- 'net group'
- 'ipconfig'
- 'systeminfo'
timeframe: 5m
condition: selection | count() >= 3
| 数据源 | 猎杀目标 | |--------|---------| | Sysmon | 进程创建/注入/网络/文件 | | PowerShell Logging | 脚本执行内容 | | Windows Security | 认证/权限/策略 | | DNS Logs | C2 域名/DGA/隧道 | | Proxy/Firewall | 异常外连/大量传输 | | EDR Telemetry | 行为链 | | NetFlow | 流量模式异常 | | LDAP Logs | AD 枚举 |
分析 Sigma 仓库公开规则 → 确保你的操作不命中
常见规则绕过:
├─ "IEX(DownloadString)" 检测
│ 绕过: 使用 .NET WebClient 直接调用,不走 PS
│ 或: certutil / bitsadmin / curl 替代
│
├─ "cmd.exe spawned by outlook.exe" 检测
│ 绕过: 使用 COM 对象执行,不创建子进程
│ 或: 用 VBA 调用 WMI → wmiprvse.exe 作父进程
│
├─ "lsass.exe access" 检测
│ 绕过: Handle duplicate 方式(不直接 OpenProcess)
│ 或: 使用 NanoDump 的 MiniDumpWriteDump 替代方式
│
└─ "Reconnaissance command burst" 检测
绕过: 分散执行(每个命令间隔 10+ 分钟)
或: 通过 WMI/LDAP 查询代替命令行工具
原则:让你的操作看起来像正常业务行为
网络行为正常化:
├─ C2 通信在业务时间(9am-6pm)
├─ 心跳间隔匹配正常 HTTP 刷新(不要太规律)
├─ 流量大小匹配正常 API 调用
├─ 使用目标已有的 SaaS 域名(Slack/Teams API 模仿)
└─ 避免凌晨大量数据传输
主机行为正常化:
├─ 不要短时间内执行多个侦察命令
├─ 使用目标环境已有的工具(LOLBins)
├─ 进程名/路径匹配合法程序
├─ 不要创建明显异常的用户名(admin123/test)
└─ 操作间隔模仿人类行为节奏
YARA 匹配原理:字节序列 + 条件逻辑
绕过方式:
├─ 字符串特征 → XOR/AES 加密关键字符串
├─ 字节序列 → 使用不同编译器/编译选项
├─ 文件结构 → 修改 PE header / Rich header
├─ 入口点模式 → 改变 stub / 使用合法 packer
└─ 行为签名 → 改变 API 调用顺序/方式
验证方式:
yara -r sigma_rules/ my_payload.exe # 扫描前先自测
现代 EDR 不只看签名,看行为链:
├─ Process Chain: 邮件→CMD→PowerShell→网络连接 = 恶意
├─ Memory Pattern: RWX + PE header + 远程线程 = 注入
├─ File Pattern: 写入→执行→删除 = dropper
└─ Network Pattern: DNS over HTTPS + 固定间隔 = C2
红队对策:
├─ 断开行为链 → 不要在同一进程内完成所有操作
├─ 时间分散 → 每步操作之间 Sleep 较长时间
├─ 使用合法流程 → 通过 COM/WMI/计划任务执行
├─ 避免 known-bad 组合 → 研究目标 EDR 的检测逻辑
└─ 测试 → 在同类 EDR 环境中预演
猎杀者常见盲区(可利用):
├─ 周末/节假日 → 人员不足,响应慢
├─ 正常业务流量 → 混入合法 API 调用难以区分
├─ 非标准数据源 → 如果日志未采集就看不到
├─ 加密流量 → TLS 内容不可见(除非有 TLS 解密)
├─ Cloud 环境 → 日志碎片化,跨平台关联困难
├─ 合法工具 → LOLBins 产生的日志与正常管理操作相同
└─ 告警疲劳 → 大量低优先级告警中隐藏高风险操作
操作前自检:
[ ] Sigma 公开规则是否命中我的 TTP?
[ ] 我的 C2 通信是否能被 JA3/JARM 识别?
[ ] 我的进程链是否有异常父子关系?
[ ] 我的网络模式是否有固定间隔/大小?
[ ] 我是否在短时间内执行了多个侦察命令?
[ ] 我的工具是否在 VirusTotal 上已有检出?
[ ] 目标是否部署了 Sysmon?配置了哪些规则?
[ ] 目标 EDR 是什么?我是否在同类环境测试过?
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 伪造的场景都应使用此技能