利用微信同步文章到Bear

若是图片失效:见【教程&工具】微信同步文章到Bearhtml

在我平常工做中,我会将各类互联网以及生活中产出的信息汇总到Bear,再经过Bear的云同步使我各个终端的信息保持一致。python

之前在使用有道云笔记的时候,有个功能我很喜欢,就是当看到一篇想收藏的文章的话,就能够直接右上角发送到有道云笔记,以下图:git

顺便一提:熊掌记是一款优雅、灵活的写做笔记应用。
回到正题,我如今面临的需求是能不能在看到喜欢的文章的时候,也经过相似于右上角分享一下就能够直接将文章同步到我各个终端上的Bear,最终成果以下:程序员

解决方案

要实现上述的需求,我大概思考了以下的解决方案:github

  1. 准备一个微信号(这里直接称做小号)专门接收待收藏到Bear的文章
  2. 编写一个服务监控小号的消息,好比收到推文类型的消息就进行内容提取
  3. 监控服务将提取后的内容发送到Bear(这里要求服务运行在Mac OS上)

因此在继续以前,你须要有如下条件:web

  • 基本的Python基础知识(写小脚本Python真的很方便)
  • 一台装有Bear的Mac OS

方案调研

上面的解决方案看起来仍是挺好实现,第一步不用多说,这年头谁没个小号,第二点的话,我印象中Python是有个第三方库能够直接监听微信对应帐号的消息。sql

由于这些第三方库都是基于Web版的微信,因此在使用以前我想验证下此方案是否可行,刚准备登陆网页版微信,就直接提示:shell

<error><ret>1203</ret><message>To protect your account, logging in to WeChat via the web has been suspended. Use WeChat for Windows or WeChat for Mac to log in on a computer. Download WeChat for Windows or Mac at http://wechat.com.</message></error>
复制代码

果不其然如今微信准备增强Web版本的限制了,内心凉凉的,第二步还没开始就已经被宣判死刑。数据库

只能换个思路了,怎么办。其实这一步走不通我仍是能接受的,由于我一直以为依赖Web版总有一天会挂掉,毕竟多了个依赖老是会增长复杂度。bash

能不能依靠客户端?

咱们知道,微信数据是有同步功能的,开发过客户端的都知道,这就意味着微信的数据必然保存一份在客户端本地系统上。

因此对于第二点的解决思路就转换成了如何获取微信保存在客户端本地的数据,找到某个软件的数据文件夹天然是很简单的事情,好比微信客户端的数据就存放在:

# howie6879是个人用户名,请自行替换
/Users/howie6879/Library/Containers/com.tencent.xinWeChat/Data/Library/Application Support/com.tencent.xinWeChat/2.0b4.0.9
复制代码

具体有以下目录:

├── 988eebd1078a0d794bff2b6f5c8d5176
├── Avatar
├── CGI
├── CrashReport
├── KeyValue
├── MMResourceMgr
├── checkVersionFile
├── d41d8cd93400b204e9800998ecf8427e
├── f965739b566114f907dc394322e1e826
├── topinfo.data
├── upgradeHistoryFile
├── whatsNewVersionFile
└── wx.dat

8 directories, 5 files
复制代码

不知道上面那三个32位的字符串你们看起来熟悉不熟悉:

一想到32,就是md5加密,我第一反应就是对于每一个登陆帐号的id加密值,咱们先无论,直接进去看更深一层的文件夹:

├── Account
├── Avatar
├── Contact
├── Favorites
├── FileStateSync
├── FunctionMsg
├── Group
├── Message
├── RevokeMsg
├── Session
├── Stickers
├── Sync
├── complexSearch
├── mmexpt
└── newabtest

15 directories, 0 files
复制代码

Message出来了,这是否是咱们想要的呢?再往下看里面的目录:

├── MessageTemp
├── fts
├── msg_0.db
├── msg_0.db-backup
├── msg_0.db-shm
├── msg_0.db-wal
├── msg_1.db
复制代码

若是你登陆过该台电脑并同步过信息,那么不出意外会有挺多*.db后缀的文件。大胆地猜想一下,这是否是咱们想要的聊天数据存放路径呢?

不要管太多,先看看总不会错,通常本地存储的数据库,我们程序员第一反应应该就是SQLite,要不要试试?

sqlite3 Message/msg_0.db
sqlite> .schema
Error: file is not a database
sqlite>
复制代码

??提示不是数据库,此时陷入了瓶颈,怎么就不是数据库了呢。反思一下,是否是打开的姿式不对。

会不会是加密了?依照这个思路,我了解到有一款基于SQLite的扩展数据库[SQLCipher](github.com/sqlcipher/s…SQLCipher是一个在SQLite基础之上进行扩展的开源数据库,它主要是在SQLite的基础之上增长了数据加密功能。

实践证实,我猜测的是对的,接下来主要作的怎么打开Message/msg_0.db这个文件并成功读取里面的数据。

最后我参考到一份有意思的问答,我就是参考这个问答对数据库进行解密,这里我复述一下:

  • 打开微信,可是先不登陆
  • 打开终端,输入lldb -p $(pgrep WeChat)
  • 会看到进入了lldb,而后输入br set -n sqlite3_key,按回车
  • lldb中,输入c,按回车
  • 打开微信并扫码登陆
  • 而后回到lldb中,输入memory read --size 1 --format x --count 32 $rsi

此时就会获得如下相似的输出:

0x600003888340: 0xd1 0x05 0x29 0x04 0x75 0xc5 0x45 0x05
0x600003888348: 0x92 0x26 0xa1 0x65 0x95 0xe5 0x15 0x3f
0x600003888350: 0xf3 0xc7 0x43 0x85 0x05 0x35 0x45 0x3d
0x600003888358: 0x84 0xc8 0x64 0xe5 0x35 0x65 0x45 0xe2
复制代码

去掉冒号前面的那一串,后面是四行八列的数据,再去除掉0x空格\n等,就会获得一串64位的字符串,举个例子:

df012f587cc546000025a56599e81530f9cc49800329423d8ec460e1386549e2
复制代码

这就是咱们进入数据库的钥匙,接下来,请安装sqlcipher的相关软件,如:

brew install sqlcipher
brew cask install db-browser-for-sqlite
复制代码

让咱们用db-browser-for-sqlite打开db后缀的文件看看有什么不同吧:

点击OK,成功打开!

随便进入一个表:

很显然,咱们成功获取了本地的聊天记录,总算将第二步流程打通了,现在咱们能够监控发送收藏文章的微信帐户的聊天记录,只要收到此帐号发来的推文消息,此时监控服务能够立马反应过来并解析发送到Bear。

有个小问题,怎么知道发推文的帐号在哪一个库哪一个表呢?能够这样看,在电脑上登陆发推文的帐号,打开文件userinfo.data

cd /Users/howie6879/Library/Containers/com.tencent.xinWeChat/Data/Library/Application Support/com.tencent.xinWeChat/2.0b4.0.9/988eebd1023a0d794bff2b6f5c8d5176/Account
cat userinfo.data
复制代码

大概输出以下:

":BHPpx��127417592694754732��wxid_epXXXXXXXfj12�    Howie6879�老胡的储物柜�
复制代码

这里很明显个人wxid就是:wxid_epXXXXXXXfj12,那么对应须要监控的表名就是:Chat_md5(wxid_epXXXXXXXfj12),形式如同这样

Chat_f965739xxxx114fxxxxc394322exxxx
复制代码

随后实如今库里面找到对应的表便可,我本机发现对应帐户的表存在于库 msg_5.db中。

接下来要作的事情就很简单了,就是将提取后的内容发送到Bear,这里能够利用X callback url Scheme documentation,好比你在终端输入:

open 'bear://x-callback-url/create?title=Test%20Bear&text=Hello%20Bear'
复制代码

立马就能够看到Bear自动创建了一篇笔记

编码实现

终于到了编码阶段,好心酸:

第一步,拿到必需要的常量:

  • S_ACCOUNT_ID:微信发送帐户ID,能够在Account/userinfo.data下查看
  • R_ACCOUNT_ID:微信接收帐户ID,同上
  • RAW_KEY:解密Key,就是上面介绍的64位字符串
  • DB_PATH_TEM:定义的是消息DB路径,好比:"/Users/howie6879/Library/Containers/com.tencent.xinWeChat/Data/Library/Application Support/com.tencent.xinWeChat/2.0b4.0.9/{0}/Message/"

定义这四个常量,接下来的事情就一路顺风了哈,我将项目开源在Github,地址见w2b,接下来我直接说说怎么用:

git clone https://github.com/howie6879/w2b
cd w2b
# 推荐使用pipenv 你也可使用本身中意的环境构建方式
pipenv install --python=/Users/howie6879/anaconda3/envs/python36/bin/python3.6  --skip-lock
# 运行前须要填好配置文件
pipenv run python w2b/run.py
复制代码

随后,会有日志输出:

[w2b] pipenv run python w2b/run.py                                                                                                
Loading .env environment variables…
[2019:09:13 09:16:35] INFO  w2b  目标表 Chat_f965739b676114fxxxxc394322e1e826 存在于库 msg_5.db
复制代码

好,代码跑起来后,接下来电脑上登陆你的小号(也就是接收微信文章的微信号),而后在手机上登陆发送文章的微信号,最终成功就和文章一开始的动图同样了~

搞定收工,有兴趣欢迎关注个人公众号:

相关文章
相关标签/搜索