WeChat macOS 数据库解密与查询工具。支持通过 key extract(LLDB hook)提取密钥,解密并查询 WeChat 4.1.7.x / 4.1.8.x 的 Apple SEE 加密 SQLite 数据库。

支持范围

  • 平台:macOS(arm64 / Apple Silicon)
  • WeChat 版本:4.1.7.x / 4.1.8.x

前置条件

密钥提取需要 SIP 关闭(SIP enabled 时 task_for_pid 被内核拒绝,即使 root 也不行),通常不需要 sudo。如果你已有密钥,可以跳过 SIP 要求,直接用 key set 手动录入。

key extract(LLDB 方式)还需要:

  1. sudo DevToolsSecurity -enable
  2. sudo dscl . append /Groups/_developer GroupMembership $USER
  3. xcode-select --install(提供 lldbpython3

安装

从 Release 下载(推荐)

前往 Releases 下载预编译二进制(macOS arm64),或使用命令行:

# 下载最新 release
curl -fSL "$(curl -fsSL https://api.github.com/repos/pandorafuture/wx-cli/releases/latest \
  | grep -o '"browser_download_url": "[^"]*macos-arm64[^"]*"' \
  | cut -d'"' -f4)" -o wx-cli.tar.gz
tar xzf wx-cli.tar.gz

# 安装到 PATH
mkdir -p ~/.local/bin
mv wx-cli ~/.local/bin/
chmod +x ~/.local/bin/wx-cli
wx-cli --version

从源码构建

# 需要 Rust 工具链(rustup 安装即可)
cargo build --release

编译产物位于 target/release/wx-cli

部署二进制

mkdir -p ~/.local/bin
cp target/release/wx-cli ~/.local/bin/wx-cli
chmod +x ~/.local/bin/wx-cli

# 确保 PATH 包含该目录
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc

wx-cli --version

AI 编程助手集成

本项目提供 Agent Skill,安装后 Claude Code、Codex、Cursor 等 AI 编程助手可直接协助查询微信数据:

npx skills add pandorafuture/wx-cli

使用

1. 检查环境

wx-cli doctor       # 检查 SIP、DevToolsSecurity、_developer 组、LLDB/python3
wx-cli status       # 查看 WeChat 运行状态和所有账号密钥/缓存状态

2. 提取密钥

# LLDB hook 提取密钥 — 会重启 WeChat,通常不需要 sudo
wx-cli key extract --timeout 120

# 查看已保存的密钥
wx-cli key list

key extract 通过 LLDB hook 捕获 PBKDF2 调用获取原始密钥,覆盖所有数据库。

手动设置密钥:

wx-cli key set <account> <64-hex-key>          # 数据库密钥
wx-cli key set-image <account> <image-key>     # 图片密钥

3. 解密数据库

wx-cli decrypt                # 自动解密到缓存目录
wx-cli decrypt --incremental  # 增量解密(只处理变化的文件)

# 手动指���路径和密钥
wx-cli decrypt -k <64位hex密钥> -d /path/to/xwechat_files/<account_dir> -o /tmp/decrypted

4. 查询聊天记录

wx-cli sessions --limit 10             # 最近会话
wx-cli contacts --search 张三           # 搜索联系人
wx-cli query 张三 --limit 20            # 查某人的消息
wx-cli search 周末 --limit 20           # 全局关键词搜索
wx-cli query 张三 --type text           # 按消息类型过滤
wx-cli query 周末爬山群                  # 群聊消息
wx-cli export 张三 -o /tmp/export --all --format json  # 导出会话
wx-cli watch --poll --poll-ms 3000      # 实时监听新消息

如果本机已启动 server run 服务,查询命令会自动复用 REST API(默认探测 http://127.0.0.1:9100)。可用 --no-server 强制本地查询,或 --server-only 强制远程。

5. 媒体解密

wx-cli decode-image input.dat -d <account_data_dir> -o output.png     # 解密图片
wx-cli decode-image /path/to/dat_dir/ -d <account_data_dir> -o /tmp/  # 批量解密
wx-cli media extract-voice --media-dir <dir> <svr_id> -o voice.mp3    # 提取语音(需 ffmpeg)
wx-cli media decrypt-video encrypted.bin --seed 2105122989 -o video.mp4  # 解密视频号视频

6. HTTP API 服务

wx-cli server run                              # 启动(默认 127.0.0.1:9100)
wx-cli server run --host 0.0.0.0 --token mysecret  # 远程访问(必须设 token)
wx-cli server status                           # 查看状态
wx-cli server stop                             # 停止
wx-cli server restart                          # 重启

REST 端点:/api/v1/health/api/v1/sessions/api/v1/contacts/api/v1/messages/api/v1/search/api/v1/media/api/v1/events(SSE)。

所有查询命令加 --format json 可获取 JSON 格式输出。

命令一览

命令 说明
wx-cli status 查看 WeChat 运行状态
wx-cli doctor 检查环境(SIP 等)
wx-cli key extract LLDB hook 提取密钥
wx-cli key list 查看已保存密钥
wx-cli key set <account> <key> 手动设置密钥
wx-cli key set-image <account> <image-key> 手动设置图片密钥
wx-cli decrypt 解密数据库
wx-cli sessions 最近会话列表
wx-cli contacts --search <名字> 搜索联系人
wx-cli query <联系人> 查询消息
wx-cli search <关键词> 全局搜索
wx-cli export <联系人> 导出会话
wx-cli watch 实时监听新消息
wx-cli decode-image <路径> 解密图片
wx-cli media extract-voice 提取语音
wx-cli media decrypt-video 解密视频号视频
wx-cli server run 启动 HTTP API 服务
wx-cli server status/stop/restart 管理服务
wx-cli paths 查看所有数据路径
wx-cli info <db> 查看数据库加密状态

Contact Hiding

按账号隐藏指定联系人、群聊或带特定标签的联系人。启用后,查询、导出、监控等命令默认应用隐藏规则(全文搜索除外)。

配置文件:~/Library/Application Support/wx-cli/config/settings.toml

[accounts."<account_id>"]
ignore_contacts = ["wxid_xxx", "12345@chatroom"]
ignore_tags = ["同事", "客户"]

本地命令支持 --show-hidden 忽略隐藏规则查看完整结果。search 当前不会自动应用隐藏配置。

文件路径

类别 路径(macOS) 用途 可删除?
Config ~/Library/Application Support/wx-cli/config/ 密钥、设置 否(先备份)
Cache ~/Library/Caches/wx-cli/ 解密后数据库 可(重新 decrypt)
State ~/Library/Application Support/wx-cli/state/ 服务运行时元数据
Logs ~/Library/Logs/wx-cli/ 服务日志
Temp $TMPDIR/wx-cli/ 密钥提取临时文件

使用 wx-cli paths 查看所有路径。清理缓存:rm -rf ~/Library/Caches/wx-cli/

项目结构

wx-cli/
├── crates/
│   ├── wx-decrypt/     # 核心解密库(KDF、逐页解密、整库解密)
│   ├── wx-keychain/    # 密钥提取(LLDB hook)与本地存储
│   ├── wx-cli/         # CLI 入口
│   ├── wx-db/          # 数据库查询(联系人、消息、会话、群聊)
│   ├── wx-media/       # 媒体解密(图片、语音、视频)
│   ├── wx-monitor/     # 实时消息监听与增量监控
│   ├── wx-context/     # 账号解析、解密缓存、联系人解析
│   └── wx-paths/       # 平台路径管理

常见问题

key extract 超时

  • 确认 WeChat 已弹出登录界面并完成登录
  • 增加超时:--timeout 300
  • 检查日志:$TMPDIR/wx-cli/lldb/wx_cli_lldb_output.txt

SIP / DevToolsSecurity 报错

密钥提取需要 SIP 关闭。重启进入恢复模式执行 csrutil disable,然后运行 wx-cli doctor 逐项检查。

解密后数据库无法打开

  • wx-cli key list 确认密钥正确
  • wx-cli info <db> 检查文件是否为加密状态
  • 确认 WeChat 版本在 4.1.7.x / 4.1.8.x 范围内