skills/dfir/emergency-response/SKILL.md
应急响应方法论。当目标主机疑似被入侵、需要排查后门/木马/异常进程/异常账户、或需要进行安全事件溯源分析时使用。覆盖 Linux 和 Windows 双平台的账户审计、进程排查、网络连接分析、启动项/计划任务检查、日志分析、Rootkit 检测
npx skillsauth add wgpsec/AboutSecurity emergency-responseInstall 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.
Linux + Windows 双平台入侵排查操作手册。按阶段推进,每步产出明确结论后再进入下一步。
主机疑似被入侵?
├─ 1. 确认事件范围
│ ├─ 单台主机 → 直接排查
│ └─ 多台/不明 → 先网络隔离,再逐台排查
├─ 2. 判断操作系统
│ ├─ Linux → Phase 2
│ └─ Windows → Phase 3
├─ 3. 确认当前权限
│ ├─ root/Administrator → 可完整排查
│ └─ 普通用户 → 先提权或协调管理员权限
└─ 4. 保全证据(排查前)
├─ 内存快照(如有条件)
├─ 磁盘镜像(关键服务器)
└─ 记录当前时间戳,后续所有发现标注时间
关键原则:
排查清单:
# 1. 查找特权用户(uid=0 应该只有 root)
awk -F: '$3==0{print $1}' /etc/passwd
# 2. 查找可远程登录的账户(有密码 hash 的账户)
awk '/\$1|\$6/{print $1}' /etc/shadow
# 3. 检查 sudo 权限异常(非管理员不应有 ALL 权限)
grep -v "^#\|^$" /etc/sudoers | grep "ALL=(ALL)"
cat /etc/sudoers.d/*
# 4. 检查 SSH 授权密钥(攻击者常植入公钥)
find / -name "authorized_keys" -exec ls -la {} \; -exec cat {} \;
# 5. 查看最近登录记录
lastlog # 所有用户最后登录时间
last # 历史登录/注销记录
lastb # 失败登录记录(暴力破解痕迹)
判断标准:
| 发现 | 风险等级 | 处置 |
|------|---------|------|
| uid=0 的非 root 用户 | 高 | 立即禁用:usermod -L <user> |
| 未知用户有 sudo ALL 权限 | 高 | 移除 sudoers 条目 |
| 未知 SSH 公钥 | 高 | 记录公钥指纹后删除 |
| 异常时段登录记录 | 中 | 关联 IP 溯源 |
# 1. 检查异常网络连接(重点关注 ESTABLISHED 和 LISTEN)
netstat -antlp | grep -E "ESTABLISHED|LISTEN"
# 或
ss -antlp
# 2. 根据可疑连接 PID 定位进程
ls -la /proc/<PID>/exe # 进程对应的可执行文件
cat /proc/<PID>/cmdline # 完整命令行
ls -la /proc/<PID>/fd # 打开的文件描述符
# 3. 检查异常进程
ps aux --sort=-%cpu | head -20 # CPU 占用排序(挖矿检测)
ps aux --sort=-%mem | head -20 # 内存占用排序
# 4. 检查隐藏进程(进程名以 . 开头或伪装为内核线程)
ps -ef | grep -E "^\S+\s+\d+.*\[.*\]" | grep -v "\[kworker"
判断标准:
/proc/PID/exe -> (deleted)) → 恶意进程驻留内存# 1. 检查 crontab(所有用户)
for user in $(cut -f1 -d: /etc/passwd); do
crontab -l -u $user 2>/dev/null && echo "=== $user ==="
done
cat /etc/crontab
ls -la /etc/cron.d/ /etc/cron.daily/ /etc/cron.hourly/ /etc/cron.monthly/ /etc/cron.weekly/
# 2. 检查 systemd 服务(关注非官方和最近修改的)
systemctl list-unit-files --type=service | grep enabled
find /etc/systemd/system/ /usr/lib/systemd/system/ -name "*.service" -mtime -7
# 3. 检查 rc.local 和 init.d
cat /etc/rc.local
ls -la /etc/init.d/
ls -la /etc/rc.d/rc*.d/ 2>/dev/null
# 4. 检查 bashrc/profile 植入
grep -r "curl\|wget\|python\|bash -i\|/dev/tcp" /etc/profile* /etc/bashrc /root/.bashrc /home/*/.bashrc 2>/dev/null
重点关注:
# 1. 查找最近修改的文件(以 3 天为例,根据事件时间调整)
find / -mtime -3 -type f -not -path "/proc/*" -not -path "/sys/*" | head -100
# 2. 查找 SUID/SGID 文件(提权后门常见手段)
find / -perm -4000 -type f 2>/dev/null
find / -perm -2000 -type f 2>/dev/null
# 3. 检查 /tmp 及隐藏目录
ls -la /tmp/ /var/tmp/ /dev/shm/
find / -name ".. " -o -name "..." -o -name ".hidden" 2>/dev/null
# 4. WebShell 检测(Web 服务器目录)
find /var/www/ -name "*.php" -mtime -7
grep -rl "eval\|system\|exec\|passthru\|shell_exec\|base64_decode" /var/www/ 2>/dev/null
# 5. 检查文件时间戳篡改(mtime 与 ctime 不一致)
stat <可疑文件> # 对比 Modify 和 Change 时间
| 日志文件 | 用途 | 查看方式 |
|----------|------|---------|
| /var/log/auth.log 或 /var/log/secure | SSH 登录、sudo、su | grep "Accepted\|Failed" /var/log/auth.log |
| /var/log/wtmp | 登录/注销记录 | last -f /var/log/wtmp |
| /var/log/btmp | 失败登录 | lastb -f /var/log/btmp |
| /var/log/cron | 定时任务执行记录 | cat /var/log/cron |
| /var/log/messages 或 /var/log/syslog | 系统事件 | grep -i "error\|warning\|fail" /var/log/messages |
| ~/.bash_history | 命令历史 | cat /root/.bash_history |
# 暴力破解检测:统计失败登录 IP
grep "Failed password" /var/log/auth.log | awk '{print $(NF-3)}' | sort | uniq -c | sort -rn | head -20
# 成功登录排查:关注非常规 IP 和时段
grep "Accepted" /var/log/auth.log | awk '{print $1,$2,$3,$9,$11}'
# 提权行为检测
grep "sudo:" /var/log/auth.log | grep -v "session opened\|session closed"
# 方法 1: chkrootkit
apt install chkrootkit -y # 或 yum install chkrootkit
chkrootkit
# 方法 2: rkhunter
apt install rkhunter -y # 或 yum install rkhunter
rkhunter --update
rkhunter --check --sk
# 方法 3: 手动检查(工具不可信时)
# 比较系统命令 hash(与已知干净环境对比)
md5sum /usr/bin/ps /usr/bin/netstat /usr/bin/ls /usr/bin/find /usr/bin/top
# 检查 LD_PRELOAD 劫持
echo $LD_PRELOAD
cat /etc/ld.so.preload
# 检查内核模块
lsmod | grep -v "^Module"
:: 1. 查看当前登录会话
query user
:: 2. 列出所有用户和管理员组成员
net user
net localgroup administrators
:: 3. 检查隐藏/克隆账户
:: 隐藏账户名末尾带 $
wmic useraccount list full
:: 对比注册表 SAM 与 net user 结果
:: HKLM\SAM\SAM\Domains\Account\Users(需 SYSTEM 权限)
:: 4. 踢出可疑会话
logoff <SessionID>
辅助工具:
wmic useraccount get name,sid —— SID 末尾非 500/501 的管理员需核实:: 1. 查看所有网络连接及对应进程
netstat -ano | findstr "ESTABLISHED LISTENING"
:: 2. 根据 PID 查进程信息
tasklist /FI "PID eq <PID>" /V
wmic process where processid=<PID> get name,executablepath,commandline
:: 3. 检查可疑进程
tasklist /V
wmic process get name,processid,executablepath,commandline /format:list
:: 4. 查看网络代理配置(是否被篡改)
REG QUERY "HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings"
:: 5. 查看路由表
route print
判断标准:
:: 1. 检查注册表启动项
REG QUERY "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Run"
REG QUERY "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Run"
REG QUERY "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnce"
REG QUERY "HKLM\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Run"
:: 2. 检查计划任务
schtasks /query /fo LIST /v
:: 3. 检查启动文件夹
dir "%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup"
dir "%ProgramData%\Microsoft\Windows\Start Menu\Programs\Startup"
:: 4. 检查服务(关注非标准服务和最近创建的服务)
wmic service list brief
wmic service get name,displayname,pathname,startmode | findstr /i "auto"
:: 5. 检查启动信息
wmic startup get command,caption
重点关注:
:: 1. 查看最近访问的文件
dir %USERPROFILE%\Recent /a /o:-d
:: 2. 检查临时目录
dir %TEMP% /a /o:-d
dir %SYSTEMROOT%\Temp /a /o:-d
:: 3. 检查浏览器下载目录
dir "%USERPROFILE%\Downloads" /a /o:-d
:: 4. 查看回收站
dir C:\$Recycle.Bin /s /a
:: 5. 检查 ADS(备用数据流,可隐藏恶意代码)
dir /r <可疑目录>
检查预取文件(Prefetch):
C:\Windows\Prefetch\打开事件查看器:eventvwr.msc
日志位置:
| 日志类型 | 默认路径 | 关注内容 |
|----------|---------|---------|
| 安全日志 | %SystemRoot%\System32\Winevt\Logs\Security.evtx | 登录事件、账户管理、特权使用 |
| 系统日志 | %SystemRoot%\System32\Winevt\Logs\System.evtx | 服务安装、驱动加载、系统错误 |
| 应用程序日志 | %SystemRoot%\System32\Winevt\Logs\Application.evtx | 应用崩溃、程序错误 |
关键 Event ID:
| Event ID | 含义 | 排查价值 | |----------|------|---------| | 4624 | 登录成功 | 结合登录类型判断攻击方式 | | 4625 | 登录失败 | 暴力破解痕迹 | | 4634 | 注销 | 会话持续时间分析 | | 4672 | 特权登录 | 管理员登录事件 | | 4720 | 创建用户 | 后门账户检测 | | 7045 | 服务安装 | 持久化/横向移动痕迹 |
登录类型参考:
| 类型 | 描述 | 常见场景 | |------|------|---------| | 2 | 交互登录 | 本地控制台登录 | | 3 | 网络登录 | 共享文件夹、PsExec | | 4 | 批处理 | 计划任务 | | 5 | 服务 | 服务启动 | | 7 | 解锁 | 屏保解锁 | | 10 | 远程交互 | RDP 远程桌面 |
# PowerShell 查询安全日志(筛选登录失败)
Get-WinEvent -FilterHashtable @{LogName='Security';ID=4625} |
Select-Object TimeCreated,@{N='IP';E={$_.Properties[19].Value}} |
Group-Object IP | Sort-Object Count -Descending
# 查询新建用户事件
Get-WinEvent -FilterHashtable @{LogName='Security';ID=4720} |
Format-List TimeCreated,Message
收集所有发现 → 按时间排序 → 构建攻击链:
1. 初始入侵时间点(最早的异常记录)
2. 攻击路径(如何从入口扩展)
3. 持久化手段(留了哪些后门)
4. 数据泄露(是否有大量数据外传)
从排查中提取以下指标,用于威胁情报关联:
| IOC 类型 | 来源 | 用途 | |----------|------|------| | 恶意 IP/域名 | 网络连接、日志 | 封禁 + 情报查询 | | 文件 Hash | 可疑文件 MD5/SHA256 | VirusTotal/微步查询 | | 攻击者账户 | 新增/异常账户 | 内网横向排查 | | 恶意文件路径 | 文件系统排查 | 全网扫描同类文件 |
立即措施:
长期加固:
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 伪造的场景都应使用此技能