使用光华智慧体育小程序的 API 实现自动刷锻。使用帮助请看最后一节。
本节是本地运行脚本的说明,不会使用命令行的用户请直接参看「帮助」一节,使用 GitHub Actions 自动运行。
- 安装依赖:
pip install -r requirements.txt
- 修改
settings.json
文件中的USER_ID, FUDAN_SPORT_TOKEN
变量,需要在小程序内抓包获得,详请查看“抓包教程”章节。 - 查看刷锻路线列表:
python main.py --view
- 自动刷锻:
python main.py --route <route_id>
,其中route_id
是刷锻路线列表中的 ID。 - 可以设置里程和时间,如
--distance 1200 --time 360
,更多选项请使用python main.py --help
查看。 - (附加)环境变量
PLATFORM_OS, PLATFORM_DEVICE
可以设置刷锻的设备标识,默认值为iOS 2016.3.1
、iPhone|iPhone 13<iPhone14,5>
。
Fork 本仓库,并设置 Secret USER_ID, FUDAN_SPORT_TOKEN
即可自动在规定时间刷锻。
目前支持的场地有菜地、南区田径场和江湾田径场。
为了方便没有计算机基础知识的同学运行此脚本,特附上使用教程。
抓包教程可参考 使用 Stream 抓包 ,抓包软件可在 App Store 下载。
按照教程内的指引配置到设置证书的步骤,然后在软件内点击 Sniff Now 按钮,打开刷锻小程序刷新一下(确保小程序已经登录),再回到
Stream,点击 Stop Sniffing,然后点击 Sniff
History,选择最近的一条记录,点开后找到开头为 GET https://sport.fudan.edu.cn/sapi
的任意一条记录,点进去选择 Request,在
Request Line 中有 userid=xxx&token=xxx
的记录,记下这两段信息。
可参考 教程 进行相应设置。注意:需要把 Fidder 中 HTTPS 部分设置的复选框由 from browers only 改为 from all processes。
在配置完后,微信登录,右上角齿轮进入代理,端口为 127.0.0.1,端口号为 8888(默认) 登录后进入小程序并登录,在 fiddler 里找到下图中的 ID 和 token
注意,目前 Token 的有效期为 3 天。
首先,你需要注册一个 GitHub 账户,并登录该账户。
在 GitHub 页面顶部,点按按钮 Fork - Create new fork,将项目复制到自己账户名下,然后点击页面右上角自己的头像 - Your repositories -
fudan-sport-automate 进入自己刚刚复制的项目,依次点击 Settings - Secrets and variables -
Actions - New repository secret,并分别新建名为 USER_ID
和 FUDAN_SPORT_TOKEN
的两个 Secret(Secret
的值分别为刚才记下的两个值)。配置完成后脚本将在每天早中晚的刷锻时间自动运行。
GitHub 中对 Fork 的仓库不会启用脚本自动运行,因此请点击页面顶部的 Actions,然后分别点击页面左侧的 Morning Exercise、Afternoon Exercise、Evening Exercise,然后在每个页面中分别点击按钮 Enable workflow 以启用自动运行。
更新 Token 时,依次点击 Settings - Secrets and variables - Actions,找到 Repository secrets
一栏,点击下方 FUDAN_SPORT_TOKEN
右侧的铅笔按钮,更新 Token 的值。
(可选)如果需要自定义设备标识,可以新建名为 PLATFORM_OS, PLATFORM_DEVICE
的 Secret,见「使用」一节。
(可选)如果需要选择其他的跑步路线,请在 .github/workflows/*.yaml
中修改对应的参数,默认为南区体育场,可以修改为菜地。具体操作此处不详述,有需求的用户请自行学习用法。
本仓库可能会不时新增功能和修复 bug,如果你已经 Fork 本仓库,在自己复制的仓库上方可以看到一条提示:This branch is * commits behind ***,点击 Sync fork,然后点击 Update branch 即可同步到最新版本。
如果在使用过程中遇到了问题,请点击页面顶部的 Issue - New Issue,并在出现的文本框中描述你的问题。