微信 4.0 (Windows) 本地数据库解密工具。从运行中的微信进程内存提取加密密钥,解密所有 SQLCipher 4 加密数据库,并提供实时消息监听。
微信 4.0 使用 SQLCipher 4 加密本地数据库:
WCDB (微信的 SQLCipher 封装) 会在进程内存中缓存派生后的 raw key,格式为 x'<64hex_enc_key><32hex_salt>'。本工具通过扫描进程内存中的这种模式,匹配数据库文件的 salt,并通过 HMAC 验证来提取正确的密钥。
pip install pycryptodome
复制配置模板并修改:
copy config.example.json config.json
编辑 config.json:
{
"db_dir": "D:\\xwechat_files\\你的微信ID\\db_storage",
"keys_file": "all_keys.json",
"decrypted_dir": "decrypted",
"wechat_process": "Weixin.exe"
}
db_dir 路径可以在 微信设置 → 文件管理 中找到。
确保微信正在运行,以管理员权限运行:
python find_all_keys.py
密钥将保存到 all_keys.json。
python decrypt_db.py
解密后的数据库保存在 decrypted/ 目录,可以直接用 SQLite 工具打开。
python monitor_web.py
打开 http://localhost:5678 查看实时消息流。
python monitor.py
每 3 秒轮询一次,在终端显示新消息。
将微信数据查询能力接入 Claude Code,让 AI 直接读取你的微信消息。
pip install mcp
注册到 Claude Code:
claude mcp add wechat -- python C:\Users\你的用户名\wechat-decrypt\mcp_server.py
或手动编辑 ~/.claude.json:
{
"mcpServers": {
"wechat": {
"type": "stdio",
"command": "python",
"args": ["C:\\Users\\你的用户名\\wechat-decrypt\\mcp_server.py"]
}
}
}
注册后在 Claude Code 中即可使用以下工具:
| Tool | 功能 |
|---|---|
get_recent_sessions(limit) |
最近会话列表(含消息摘要、未读数) |
get_chat_history(chat_name, limit) |
指定聊天的消息记录(支持模糊匹配名字) |
search_messages(keyword, limit) |
全库搜索消息内容 |
get_contacts(query, limit) |
搜索/列出联系人 |
get_new_messages() |
获取自上次调用以来的新消息 |
前置条件:需要先完成步骤 1-2(配置 + 提取密钥)。
| 文件 | 说明 |
|---|---|
config.py |
配置加载器 |
find_all_keys.py |
从微信进程内存提取所有数据库密钥 |
decrypt_db.py |
全量解密所有数据库 |
mcp_server.py |
MCP Server,让 Claude AI 查询微信数据 |
monitor_web.py |
实时消息监听 (Web UI + SSE) |
monitor.py |
实时消息监听 (命令行) |
latency_test.py |
延迟测量诊断工具 |
微信使用 SQLite WAL 模式,WAL 文件是预分配固定大小 (4MB)。检测变化时:
解密后包含约 26 个数据库:
session/session.db - 会话列表 (最新消息摘要)message/message_*.db - 聊天记录contact/contact.db - 联系人media_*/media_*.db - 媒体文件索引本工具仅用于学习和研究目的,用于解密自己的微信数据。请遵守相关法律法规,不要用于未经授权的数据访问。