macOS 微信的“备份与恢复”功能只能从手机微信导出到 Mac, 但是微信其实又在本地存了加密的 sqlite3 数据库; 本地数据库的是一系列 *.db 文件,可以用如下命令查看,
ls -alh ~/Library/Containers/com.tencent.xinWeChat/Data/Library/Application\ Support/com.tencent.xinWeChat/*/*/Message/*.db
经过观察,微信存数据使用的是开源的 sqlcipher, 所以还是有办法导出微信在 Mac 本机的数据库的, 以下内容在 macOS 10.12, MAS 版微信 2.3.16 测试生效;
该方法依赖 lldb, 步骤如下
打开微信
命令行运行 lldb -p $(pgrep WeChat)
在 lldb 中输入 br set -n sqlite3_key
, 回车
还是在 lldb 中,输入 c
, 回车
扫码登录微信
这时候回到 lldb 界面, 输入 memory read --size 1 --format x --count 32 $rsi
, 回车
应该会输出类似于如下的数据
0x000000000000: 0xab 0xcd 0xef 0xab 0xcd 0xef 0xab 0xcd
0x000000000008: 0xab 0xcd 0xef 0xab 0xcd 0xef 0xab 0xcd
0x000000000010: 0xab 0xcd 0xef 0xab 0xcd 0xef 0xab 0xcd
0x000000000018: 0xab 0xcd 0xef 0xab 0xcd 0xef 0xab 0xcd
现在,忽略左边的地址( 0x000000000000: ,0x000000000008:),从左到右,从上到下,把形如 0xab 0xcd 的数据拼起来,然后去掉所有的 "0x"和空格、换行, 得到 64 个字符的字符串,这就是 微信数据库的 key ;(参考 https://github.com/sqlcipher/sqlcipher )
然后, 可以下一个 https://sqlitebrowser.org/ ,用来浏览之前提到的*.db 文件(每个 db 都使用的相同的 key ),注意:打开数据库的时候选择(raw key), 然后输入 0x,再输入刚才那 64 个字符;
遗留问题:*.db 文件要在另一台 PC 或 Mac 上 登录微信, 才能被关闭,否则里面的聊天记录不是最新的;当然也可以强制调用 wal_checkpoint, 不过作为土办法,在另一台电脑上登一下微信也无妨
1
AnyISalIn 2018-06-26 22:24:08 +08:00 via iPhone
itunes 备份可以拿出明文数据
|
3
mornlight 2018-07-19 02:03:00 +08:00
试了一下,还有个 wccontact db,里面是所有联系人,联系人的 m_nsUsrName 做一次 md5 后对应聊天记录 db 里以 Chat_xxx 开头的表。
终于可以把我一些有用的记录导出来了,谢谢~ |
7
AnyISalIn 2018-08-19 21:18:59 +08:00
@Citrus itunes 全量备份(不加密)之后用 iphone backup extractor 单独导出 weixin 的目录,然后最里面有一个 MM.sqlite 文件,都是明文的数据
|
8
deniswu 2019-01-10 08:40:30 +08:00
请问现在这个方法还能用吗,拿到密码后,页面大小选多少,我试了下得到的密码还是打不开。
|
9
devnkong 2019-03-17 13:05:50 +08:00
2019.3.17 亲测可用,加密方法选择 SQLCipher 3 default
|
10
zhongdian121 2019-03-26 17:45:12 +08:00
没有 lldb 的相关经验,请问
br set -n sqlite3_key 中的变量名 sqlite3_key 是怎么猜到的呢? 这个办法能够破解 msg_n.db 但是现在电脑端微信可以备份聊天记录到 Backup.db 在这个过程中,设置 sqlite3_key 断点依然能够触发, memory read --size 1 --format x --count 32 $rsi 读到的数据跟登录时触发的断点也不相同 但是就是无法用相同的方法解密 |
11
newdongyuwei 2019-06-24 10:53:04 +08:00
2019-06-24 亲测可用。赞楼主! Database Browser for SQLite 支持解密 sqlcipher 加密的数据库。Encryption setting 选择 sqlcipher3 defaults
|
12
newdongyuwei 2019-06-24 14:21:53 +08:00
@zhongdian121 我猜测是这个: https://www.zetetic.net/sqlcipher/sqlcipher-api/#sqlite3_key sqlcipher 会调用 sqlite3_key 这个函数
|
13
taohao 2019-08-08 14:45:40 +08:00
@zhongdian121 我也是这样,打开备份的数据时打不开
|
14
longalong 2019-09-06 12:01:17 +08:00
求教,我在 mac 按照教程走,最后可以在 DB broswer for sql-lite 里边看到,我现在要把 mac 里的聊天记录转到 pc 上,“遗留问题:*.db 文件要在另一台 PC 或 Mac 上 登录微信, 才能被关闭,否则里面的聊天记录不是最新的;当然也可以强制调用 wal_checkpoint, 不过作为土办法,在另一台电脑上登一下微信也无妨” 没有太理解这里的操作步骤。是指直接把 mac 里的 DB 文件复制到 PC 上 DB 文件应该在的位子就可以了吗?还是怎么操作的
|
16
zhangyccc 2020-02-12 19:31:38 +08:00
已经不行了,第一步就连不上了 lldb -p $(pgrep WeChat)
|
17
nickr 2020-07-23 20:35:06 +08:00 1
验证了. 这个方法还是可用的. 不过对于手机备份到 mac 的备份文件, 这个方法无法打开.
|
19
yuanchao 2020-08-05 21:03:22 +08:00
经过测试,这个方法在 2020-08-05 微信 Version. 2.4.2 (15063) 已失效,如哪位老哥有新的方法请 at 我,谢谢
|
20
Jyougen 2020-08-07 11:57:35 +08:00
@yuanchao Version. 2.4.2 (15063) 方法可用, 但是这种方法可以把数据导入到 iOS 的微信里吗?
|
21
leverestfish 2020-08-25 10:40:32 +08:00
@Jyougen 你好,我第一步就运行出错,同样版本号,微信软件的各种打开状态都试过,报错如下。在 lldb 前面加 sudo 也不行。
``` bash ➜ ~ lldb -p $(pgrep WeChat) (lldb) process attach --pid 97885 error: attach failed: Error 1 ``` |
22
5thcat OP @leverestfish 你的 macOS 版本是什么?
|
23
leverestfish 2020-08-25 17:01:36 +08:00
@5thcat macOS 10.15.6
|
24
knightdf 2020-08-31 23:47:04 +08:00
mac 10.15.6, wechat 2.4.2 失效了?密码打不开.db 文件
|
25
knightdf 2020-09-01 00:24:54 +08:00 1
@knightdf 最新版的用这个测试: http://xferris.cn/dao-chu-wei-xin-bei-fen-de-mac/ 亲测有效
|
26
Hovera 2020-12-05 08:49:13 +08:00
@nickr #17 是这样的,我的是 macOS 10.15.7,微信版本 2.5.0 (15731),数据库打开似乎只是自动备份的最近几天的对话记录。
对于手机微信消息至 mac 的备份应该在 Backup 文件夹(~/Library/Containers/com.tencent.xinWeChat/Data/Library/Application\ Support/com.tencent.xinWeChat/2.0b4.0.9/Backup/),里面有 backup.db ,BAK_0_TEXT,BAK_0_MEDIA,不知该如何破解。 |
27
SimonOne 2021-02-06 20:31:45 +08:00
lldb 时微信无响应,没法点击怎么办呢?
|
28
cherrychen 2021-09-13 15:51:10 +08:00
@SimonOne 打了断点吧, 可以 输入 c 或者 continue 就可以了
|
29
kevintao1024 2023-06-26 17:33:51 +08:00 1
按照操作报错了,请问怎么解决?
``` (lldb) c Process 1153 resuming Process 1153 stopped * thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1 frame #0: 0x0000000108fdfcc4 WCDB`sqlite3_key WCDB`sqlite3_key: -> 0x108fdfcc4 <+0>: mov x3, x2 0x108fdfcc8 <+4>: mov x2, x1 0x108fdfccc <+8>: adr x1, #0x2c4d7 ; "main" 0x108fdfcd0 <+12>: nop Target 0: (WeChat) stopped. (lldb) memory read --size 1 --format x --count 32 $rsi error: invalid start address expression. error: address expression "$rsi" evaluation failed ``` |