推一个机场可以走我的优惠码【88888888】相当于50多一年,trySmall可用
AFF
【科学上网】机场地址--->R星云<---机场地址【科学上网】AFF
觉得这个项目对你有帮助恰巧你需要节点的话可以看一下
这个脚本主要是为了在微信读书的阅读挑战赛中刷时长和保持天数。由于本人偶尔看书时未能及时签到,导致入场费打了水漂。网上找了一些,发现高赞的自动阅读需要挂虚拟器模拟或者用ADB模拟,实现一点也不优雅。因此,我决定编写一个自动化脚本。通过对官网接口的抓包和JS逆向分析实现。
该脚本具备以下功能:
- 自动刷阅读时长:默认计入排行榜和挑战赛,时长可调节,默认为60分钟。
- 定时运行:可部署在GitHub Action/服务器上,支持每天定时运行并推送结果到微信。
- Cookie自动更新:一次抓包后,脚本能自动获取并更新Cookie,支持长时间使用。
- 轻量化设计:本脚本实现了轻量化的编写,部署服务器、GIthub action均可运行,无需额外环境条件。
脚本逻辑还是比较简单的,main.py
与push.py
代码不需要改动。在微信阅读官网 微信读书 搜索【三体】点开阅读点击下一页进行抓包,抓到read
接口 https://weread.qq.com/web/book/read
,如果返回格式正常(如:
{
"succ": 1,
"synckey": 564589834
}
右键复制为Bash格式。
-
Fork这个仓库,在仓库 Settings -> 左侧列表中的 Secrets and variables -> Actions,然后在右侧的 Repository secrets 中添加如下值:
WXREAD_CURL_BASH
:复制read接口转换为bash的数据。PUSH_METHOD
:推送方法,可以填写你想使用的推送方式(pushplus、wxpusher、telegram)。PUSHPLUS_TOKEN
orWXPUSHER_SPT
orTELEGRAM_BOT_TOKEN
&TELEGRAM_CHAT_ID
: 推送key值。
-
在 Variables 部分,最下方添加变量:
READ_NUM
:设定每次阅读的目标次数。
-
基本属性
secrets/varables | Value | 说明 |
---|---|---|
WXREAD_CURL_BASH |
抓到的 read 接口的 curl_bash 命令 (必填) | 必须提供有效的指令 |
READ_NUM |
阅读次数,每次代表 30 秒 (可选) | 控制阅读时长,默认 60 分钟 |
PUSH_METHOD |
推送方式,可选值为 pushplus 、wxpusher 或 telegram |
选择推送方式,默认不推送 |
- 推送方式
key | 说明 | |
---|---|---|
当选择 pushplus 时 |
PUSHPLUS_TOKEN |
Token获取页 |
当选择 wxpusher 时 |
WXPUSHER_SPT |
SPT获取页 |
当选择 telegram 时 |
配置项:TELEGRAM_BOT_TOKEN & TELEGRAM_CHAT_ID 代理(可选): http_proxy &https_proxy |
Telagram配置 |
重要:除了READ_NUM配置在varables,其它的都配置在secrets里面的;需要推送PUSH_METHOD
是必填的。
- 在你的服务器上有Python运行环境即可,使用
cron
定义自动运行。 - 或者通过docker运行,将抓到的bash命令在 Convert 转化为Python字典格式,复制需要的headers与cookies即可(data不需要)。
steps1:克隆这个项目:git clone https://github.com/findmover/wxread.git
steps2:配置config.py里的headers、cookies、READ_NUM、PUSH_METHOD以及对应推送方式token
steps3:进入目录使用镜像构建容器:
docker rm -f wxread && docker build -t wxread . && docker run -d --name wxread -v $(pwd)/logs:/app/logs --restart always wxread
steps4:测试:docker exec -it wxread python /app/main.py
-
签到次数调整:只需签到完成挑战赛可以将
num
次数从120调整为2,每次num
为30秒,200即100分钟。 -
解决阅读时间问题:对于issue中提出的“阅读时间没有增加”,“增加时间与刷的时间不对等”建议保留
config.py
中的【data】字段,默认阅读三体,其它书籍自行测试。 -
GitHub Action部署/本地部署:主要配置config.py即可,Action部署使用环境变量,本地部署修改config.py里的阅读次数、headers、cookies即可。
-
推送:pushplus推送偶尔出问题,猜测是GitHub action环境问题,增加重试机制。并增加wxpusher的极简推送方式。
字段 | 示例值 | 解释 |
---|---|---|
appId |
"wbxxxxxxxxxxxxxxxxxxxxxxxx" |
应用的唯一标识符。 |
b |
"ce032b305a9bc1ce0b0dd2a" |
书籍或章节的唯一标识符。 |
c |
"0723244023c072b030ba601" |
内容的唯一标识符,可能是页面或具体段落。 |
ci |
60 |
章节或部分的索引。 |
co |
336 |
内容的具体位置或页码。 |
sm |
"[插图]威慑纪元61年,执剑人在一棵巨树" |
当前阅读的内容描述或摘要。 |
pr |
65 |
页码或段落索引。 |
rt |
88 |
阅读时长或阅读进度。 |
ts |
1727580815581 |
时间戳,表示请求发送的具体时间(毫秒级)。 |
rn |
114 |
随机数或请求编号,用于标识唯一的请求。 |
sg |
"bfdf7de2fe1673546ca079e2f02b79b937901ef789ed5ae16e7b43fb9e22e724" |
安全签名,用于验证请求的合法性和完整性。 |
ct |
1727580815 |
时间戳,表示请求发送的具体时间(秒级)。 |
ps |
"xxxxxxxxxxxxxxxxxxxxxxxx" |
用户标识符或会话标识符,用于追踪用户或会话。 |
pc |
"xxxxxxxxxxxxxxxxxxxxxxxx" |
设备标识符或客户端标识符,用于标识用户的设备或客户端。 |
s |
"fadcb9de" |
校验和或哈希值,用于验证请求数据的完整性。 |