skills/analyzing-command-and-control-communication/SKILL.md
分析恶意软件命令与控制(C2)通信协议,以了解 beacon 模式、命令结构、数据编码和基础设施。 涵盖 HTTP、HTTPS、DNS 和自定义协议 C2 分析,用于检测规则开发和威胁情报。 适用于 C2 分析、beacon 检测、C2 协议逆向工程或命令与控制基础设施绘图相关请求。
npx skillsauth add killvxk/cybersecurity-skills-zh analyzing-command-and-control-communicationInstall 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.
不适用于一般网络异常检测;本技能专门用于从恶意软件分析中了解已知或疑似 C2 协议。
scapy、dpkt 和 requests 用于协议分析和重放确定用于 C2 通信的协议和传输方式:
C2 通信通道:
━━━━━━━━━━━━━━━━━━━━━━━━━
HTTP/HTTPS: 最常见;使用标准 Web 流量进行混入
指标:定期 POST/GET 请求、特定 URI 模式、自定义请求头
DNS: 通过 DNS 查询和响应进行数据隧道传输
指标:大量 TXT 查询、长子域名、高熵值
自定义 TCP/UDP:使用非标准端口的私有二进制协议
指标:高端口上的非 HTTP 流量、未知协议
ICMP: 编码在 ICMP 回显/回复载荷中的数据
指标:具有大型或非标准载荷的 ICMP 数据包
WebSocket: 用于实时 C2 的持久双向连接
指标:WebSocket 升级后跟随二进制帧
云服务: 使用合法 API(Telegram、Discord、Slack、GitHub)
指标:非预期进程向云服务进行 API 调用
电子邮件: 使用 SMTP/IMAP 进行 C2 命令和数据外泄
指标:非电子邮件进程的自动化邮件操作
对周期性通信模式进行特征分析:
from scapy.all import rdpcap, IP, TCP
from collections import defaultdict
import statistics
import json
packets = rdpcap("c2_traffic.pcap")
# 按目标分组 TCP SYN 数据包
connections = defaultdict(list)
for pkt in packets:
if IP in pkt and TCP in pkt and (pkt[TCP].flags & 0x02):
key = f"{pkt[IP].dst}:{pkt[TCP].dport}"
connections[key].append(float(pkt.time))
# 分析每个目标的 beacon 行为
for dst, times in sorted(connections.items()):
if len(times) < 3:
continue
intervals = [times[i+1] - times[i] for i in range(len(times)-1)]
avg_interval = statistics.mean(intervals)
stdev = statistics.stdev(intervals) if len(intervals) > 1 else 0
jitter_pct = (stdev / avg_interval * 100) if avg_interval > 0 else 0
duration = times[-1] - times[0]
beacon_data = {
"destination": dst,
"connections": len(times),
"duration_seconds": round(duration, 1),
"avg_interval_seconds": round(avg_interval, 1),
"stdev_seconds": round(stdev, 1),
"jitter_percent": round(jitter_pct, 1),
"is_beacon": 5 < avg_interval < 7200 and jitter_pct < 25,
}
if beacon_data["is_beacon"]:
print(f"[!] 检测到 BEACON:{dst}")
print(f" 间隔:{avg_interval:.0f}s +/- {stdev:.0f}s({jitter_pct:.0f}% 抖动)")
print(f" 会话:{len(times)} 次,持续 {duration:.0f}s")
从捕获的流量中逆向工程消息格式:
# 基于 HTTP 的 C2 协议分析
import dpkt
import base64
with open("c2_traffic.pcap", "rb") as f:
pcap = dpkt.pcap.Reader(f)
for ts, buf in pcap:
eth = dpkt.ethernet.Ethernet(buf)
if not isinstance(eth.data, dpkt.ip.IP):
continue
ip = eth.data
if not isinstance(ip.data, dpkt.tcp.TCP):
continue
tcp = ip.data
if tcp.dport == 80 or tcp.dport == 443:
if len(tcp.data) > 0:
try:
http = dpkt.http.Request(tcp.data)
print(f"\n--- C2 请求 ---")
print(f"方法:{http.method}")
print(f"URI:{http.uri}")
print(f"请求头:{dict(http.headers)}")
if http.body:
print(f"正文({len(http.body)} 字节):")
# 尝试 Base64 解码
try:
decoded = base64.b64decode(http.body)
print(f" 解码后:{decoded[:200]}")
except:
print(f" 原始:{http.body[:200]}")
except:
pass
将观察到的模式与已知 C2 框架进行匹配:
已知 C2 框架签名:
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
Cobalt Strike:
- 默认 URI:/pixel、/submit.php、/___utm.gif、/ca、/dpixel
- Malleable C2 配置文件可自定义所有流量特征
- JA3:随配置文件变化
- Beacon 配置中的水印(每个许可证唯一)
- 配置提取:使用 CobaltStrikeParser 或 1768.py
Metasploit/Meterpreter:
- 默认分段 URI 模式:随机 4 字符校验和
- 反向 HTTP(S) 处理器模式
- Meterpreter TLV(类型-长度-值)协议结构
Sliver:
- mTLS、HTTP、DNS、WireGuard 传输选项
- Protobuf 编码消息
- 通信中的唯一植入物 ID
Covenant:
- 基于 .NET 的 C2 框架
- HTTP 加可自定义配置文件
- 基于任务的命令执行
PoshC2:
- 基于 PowerShell/C#
- HTTP 加加密载荷
- 基于 Cookie 的会话管理
# 从 PCAP 或样本中提取 Cobalt Strike beacon 配置
python3 << 'PYEOF'
# 使用 CobaltStrikeParser(pip install cobalt-strike-parser)
from cobalt_strike_parser import BeaconConfig
try:
config = BeaconConfig.from_file("suspect.exe")
print("Cobalt Strike Beacon 配置:")
for key, value in config.items():
print(f" {key}: {value}")
except Exception as e:
print(f"不是 Cobalt Strike beacon 或解析错误:{e}")
PYEOF
记录完整的 C2 基础设施和故障转移机制:
# 基础设施绘图
import requests
import json
c2_indicators = {
"primary_c2": "185.220.101.42",
"domains": ["update.malicious.com", "backup.evil.net"],
"ports": [443, 8443],
"failover_dns": ["ns1.malicious-dns.com"],
}
# 通过 Shodan 丰富信息
def shodan_lookup(ip, api_key):
resp = requests.get(f"https://api.shodan.io/shodan/host/{ip}?key={api_key}")
if resp.status_code == 200:
data = resp.json()
return {
"ip": ip,
"ports": data.get("ports", []),
"os": data.get("os"),
"org": data.get("org"),
"asn": data.get("asn"),
"country": data.get("country_code"),
"hostnames": data.get("hostnames", []),
"last_update": data.get("last_update"),
}
return None
# 通过被动 DNS 丰富信息
def pdns_lookup(domain):
# 使用 VirusTotal 被动 DNS
resp = requests.get(
f"https://www.virustotal.com/api/v3/domains/{domain}/resolutions",
headers={"x-apikey": VT_API_KEY}
)
if resp.status_code == 200:
data = resp.json()
resolutions = []
for r in data.get("data", []):
resolutions.append({
"ip": r["attributes"]["ip_address"],
"date": r["attributes"]["date"],
})
return resolutions
return []
根据分析的 C2 特征构建检测规则:
# 针对分析 C2 的 Suricata 规则
cat << 'EOF' > c2_detection.rules
# HTTP beacon 模式
alert http $HOME_NET any -> $EXTERNAL_NET any (
msg:"MALWARE MalwareX C2 HTTP Beacon";
flow:established,to_server;
http.method; content:"POST";
http.uri; content:"/gate.php"; startswith;
http.header; content:"User-Agent: Mozilla/5.0 (compatible; MSIE 10.0)";
threshold:type threshold, track by_src, count 5, seconds 600;
sid:9000010; rev:1;
)
# JA3 指纹匹配
alert tls $HOME_NET any -> $EXTERNAL_NET any (
msg:"MALWARE MalwareX TLS JA3 指纹";
ja3.hash; content:"a0e9f5d64349fb13191bc781f81f42e1";
sid:9000011; rev:1;
)
# DNS beacon 检测(高熵子域名)
alert dns $HOME_NET any -> any any (
msg:"MALWARE 疑似 DNS C2 隧道";
dns.query; pcre:"/^[a-z0-9]{20,}\./";
threshold:type threshold, track by_src, count 10, seconds 60;
sid:9000012; rev:1;
)
# 基于证书的检测
alert tls $HOME_NET any -> $EXTERNAL_NET any (
msg:"MALWARE MalwareX 自签名 C2 证书";
tls.cert_subject; content:"CN=update.malicious.com";
sid:9000013; rev:1;
)
EOF
| 术语 | 定义 | |------|------------| | Beaconing(信标) | 恶意软件定期向 C2 服务器发送的签到通信,通常带有抖动以避免模式检测 | | Jitter(抖动) | 应用于 beacon 间隔的随机化(如 60s +/- 15%),使时序模式不可预测、更难检测 | | Malleable C2 | Cobalt Strike 功能,允许操作者自定义 C2 流量的所有方面(URI、请求头、编码),以模仿合法服务 | | Dead Drop(投弃站) | 中间位置(粘贴网站、云存储、社交媒体),C2 命令发布于此供恶意软件检索 | | 域前置(Domain Fronting) | 在 TLS SNI 中使用受信任的 CDN 域,同时路由到不同后端,使 C2 流量看似流向合法服务 | | Fast Flux(快速通量) | 快速更改 C2 域的 DNS 记录,分散到许多 IP,以抵抗清除工作 | | C2 框架 | 提供 C2 服务器、植入物生成器和操作者界面的软件工具包(Cobalt Strike、Metasploit、Sliver、Covenant) |
场景背景:一个恶意软件样本通过 TCP 8443 端口使用未知二进制协议与 C2 服务器通信。需要解码该协议以了解命令集并构建检测签名。
方法:
常见陷阱:
C2 通信分析报告
===================================
样本: malware.exe(SHA-256:e3b0c44...)
C2 框架: Cobalt Strike 4.9
BEACON 配置
C2 服务器: hxxps://185.220.101[.]42/updates
Beacon 类型: HTTPS(反向)
休眠: 60 秒
抖动: 15%
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)
URI(GET): /dpixel
URI(POST): /submit.php
水印: 1234567890
协议分析
传输: HTTPS(TLS 1.2)
JA3 哈希: a0e9f5d64349fb13191bc781f81f42e1
证书: CN=Microsoft Update(自签名)
编码: Base64 加 XOR 密钥 0x69
命令格式: [4B 长度][4B 命令 ID][载荷]
命令集
0x01 - Sleep 更改 beacon 间隔
0x02 - Shell 执行 cmd.exe 命令
0x03 - Download 从 C2 传输文件
0x04 - Upload 外泄文件到 C2
0x05 - Inject 进程注入
0x06 - Keylog 启动键盘记录
0x07 - Screenshot 截屏
基础设施
主要: 185.220.101[.]42(AS12345,托管商,荷兰)
备用: 91.215.85[.]17(AS67890,VPS 提供商,俄罗斯)
DNS: update.malicious[.]com -> 185.220.101[.]42
注册商: NameCheap
注册日期: 2025-09-01
检测签名
SID 9000010: HTTP beacon 模式
SID 9000011: JA3 TLS 指纹
SID 9000013: C2 证书匹配
testing
设计并执行社会工程学渗透测试,包括钓鱼、语音钓鱼、短信钓鱼和物理借口活动,以衡量人员安全韧性并识别培训差距。
testing
主持结构化的事件后审查,以识别根本原因、记录有效和无效的措施,并提出可操作的改进建议以提升未来的事件响应能力。
testing
通过分析举报的邮件、提取指标、评估凭据受攻陷情况、在全组织范围隔离恶意邮件并修复受影响账号来响应网络钓鱼事件。涵盖邮件头分析、URL/附件沙箱检测和邮箱范围清除操作。适用于网络钓鱼响应、邮件事件、凭据钓鱼、鱼叉式网络钓鱼调查或钓鱼修复相关请求。
tools
票据传递(Pass-the-Ticket,PtT)是一种横向移动技术,使用窃取的 Kerberos 票据(TGT 或 TGS)在不知道用户密码的情况下向服务进行认证。通过从已控制的主机内存中提取 Kerberos 票据,攻击者可以将这些票据注入自己的会话以模拟票据所有者。