有人 #10 提到教务处注意到了抢课脚本,请自行判断并合理使用这个软件,当你的频率够低时这只是个自动化软件,且你发送的请求在服务器看来和手点没差。脚本默认的速度很慢,不应该对服务器产生压力。如果你不理解这个脚本的原理,不能自行判断风险,你不应该使用这个脚本。
欢迎 Star!欢迎 pr!
适用:时间优先选课阶段(即本学期末,下学期初)
支持:
- 请求速度控制
- 服务器运行
- 整点运行
- 自动重试
- 自动停止
pip install ruccourse
# pip install ruccourse[all] # 包含 simpleaudio,用于抢课铃声提示
ruclogin # only need to run once
ruccourse --verbose
关于 ruclogin 这个包,你可以查看 ruclogin 的具体文档。
像这样,请注意,密码的输入不带回显(即不显示你输入的内容),你只需要直接输入,然后回车。
(base) PS D:\Code\RUC-CourseSelectionTool> pip install ruccourse
....
(base) PS D:\Code\ruclogin> ruclogin
username, type enter to skip: 2021201212
password, type enter to skip:
browser(Chrome/Edge/Chromium), type enter to skip:
driver_path, type enter to skip:
Config D:\Program\anaconda3\Lib\site-packages\ruclogin\config.ini updated:
Username: 2021201212
Password: ******
Browser: Chrome
driver_path: D:/Other/driver/chromedriver.exe
Test login? (Y/n):
你好, 信息学院 xxx from v.ruc.edu.cn
你好,xxx 图灵实验班(信息学拔尖人才实验班),你一共修了123学分,48门课,平均绩点3.9,专业排名第2名 from jw.ruc.edu.cn
driver init time: 4.749s
v.ruc.edu.cn get cookies time: 1.587s, check cookies time: 0.348s
jw.ruc.edu.cn get cookies time: 1.925s, check cookies time: 0.395s
(base) PS D:\Code\RUC-CourseSelectionTool> ruccourse --verbose
2023-12-20 17:10:25,184 - IMPORTANT_INFO - 脚本开始运行
2023-12-20 17:10:25,184 - IMPORTANT_INFO - 加载配置文件 D:\Program\anaconda3\Lib\site-packages\ruccourse\config.ini
2023-12-20 17:10:25,184 - IMPORTANT_INFO - 日志输出到 D:\Program\anaconda3\Lib\site-packages\ruccourse\ruccourse.log
2023-12-20 17:10:25,184 - ERROR - 抢课列表为空
你需要先手动选择要抢的课,是否现在开始选择(请确保你已经正确配置好 ruclogin) Y/n:
请等待脚本输出“等待浏览器被关闭...”后,再开始选择课程,选择后关闭浏览器。按回车键继续...
在浏览器里,选一遍所有你想选的课程(即使失败)
等待浏览器被关闭...
你选择的课程是: 信息检索导论01班
2023-12-20 17:10:25,185 - IMPORTANT_INFO - 学期:2023-2024学年夏季学期
2023-12-20 17:10:25,185 - IMPORTANT_INFO - 待抢课程:信息检索导论01班
2023-12-20 17:10:25,185 - IMPORTANT_INFO - gap=0,脚本将不间断执行
2023-12-20 17:10:26,580 - INFO - req/s: 17.621 tru_reqs/s: 15.663 total: 18
2023-12-20 17:10:27,571 - INFO - req/s: 21.356 tru_reqs/s: 20.362 total: 43
2023-12-20 17:10:28,588 - INFO - req/s: 22.442 tru_reqs/s: 20.792 total: 68
2023-12-20 17:10:28,689 - IMPORTANT_INFO - 抢到 信息检索导论01班
2023-12-20 17:10:28,919 - IMPORTANT_INFO - 脚本已停止
- 见
ruccourse --help
- 默认情况下(即不加
--verbose
参数时)抢到课或同类别选满会输出到控制台,速度监控会输出到文件,这样你可以一眼看出有没有抢到课 - 配置文件中包含更多可设置量
- 特别地,如果你需要抢课铃声提示功能,请手动
pip install simpleaudio
,然后在配置文件中修改silent
项
-
拥有 cookies 相当于拥有微人大的完全访问权限,请不要和任何人分享。
执行
ruclogin --reset
可以将所有信息初始化(包括配置文件内保存的用户名密码,以及缓存的 cookies)。 -
脚本默认会上传请求次数等信息到服务器,这些信息不包含个人隐私,将用于改进抢课体验和便于脚本作者了解这个脚本的被使用情况,
在被大规模使用前跑路。你可以在配置文件中关闭,但我认为:- 如果你有能力阅读源码,并判断出这个功能不会泄露你的个人隐私,那么你不需要关闭这个功能。
- 如果你没有能力阅读源代码,那么你从一开始就不应该使用这个脚本,因为这个脚本高度涉及隐私。
-
当你通过
pip install -U ruccourse
更新脚本时,你的配置文件会被覆盖,请提前备份。值得备份的文件有config.ini
和courses.json
,你可以通过ruccourse -V
来检查他们的路径。
Q:如何更新抢课列表,或者说想抢别的课?
A:ruccourse --recollect
Q: 怎么检验抢课脚本的效果?
A: 你可以 ruccourse --recollect
重新选一次课,并选择还有名额的课,同时在关闭浏览器前手动退选这门课。此时关闭浏览器,脚本开始运行,你应该会看到其显示抢课成功,同时教务处网站也会显示你抢到了这门课。
Q:运行一段时间后卡住,表现为不再输出日志?
A:见 #8,期待有缘人修复 BUG,目前的解决方案是:已知微人大总是整 5 分钟放出课程,所以你可以定时重启本脚本,#8 就是一种方案。
Q:运行原理?
A:暴力发选课请求,直到抢到,或者同类课达到选课上线。其实抢课的实现不复杂,但是之前的测试表明,cookies 容易失效,所以现在配合 ruclogin 可以保证抢课不中断。
Q:有没有被检测的风险?
A:脚本默认参数是 10/s,已经足够,同时脚本禁止过高的请求速度,如果你清楚你在做什么,请自行魔改源代码去掉这个限制,从原理上,通过脚本和在网页上手动点击并无本质区别,但频率太高对服务器是个压力,同时可能会提高服务器维护成本。
题外话:其实脚本每次只无脑发送选课请求而不请求当前各课程的剩余人数,只要你的频率小于等于正常访问,甚至你对服务器的压力比正常浏览器访问还低。
Q:为什么是半自动化?
A:抢课请求里面有一大堆意义不明,命名不明的不知道怎么填,不填还会炸的参数,研究清楚太费劲,遂采用抓包的方法。
Q:控制台输出 “WARNING - 44.55% 的请求被拒绝,真实请求速度为 29.251 req/s,最低请求速度为 4.897 req/s”
A:系统有时候会返回“服务器繁忙,请稍后再试!”,这表示一个无效请求,当最低速度(对某课程)超过阈值时(比例 * 期望总请求速度 / 课程数),脚本会输出警报,你需要自行判断其程度是否会影响你的抢课,比例可以在 config.ini
文件里调整。注意,如果你同时打开了动态调整请求速度,那么其调整的是真实请求速度,即被服务器正确处理的请求。
Q:怎么支持一上来就抢课?
A:不支持,必须先抓包,一个可能的方法是提前抓包,下阶段抢课,但是实测参数不同,你可以试试。
Q:服务器上怎么运行?
A:将本地的抢课列表文件(运行时有输出其路径)上传到服务器对应目录下,其他类似。
Q: 遇到了其他报错。
A: 你可以尝试 ruccourse --debug
以抛出错误,在这之前,你或许需要先尝试 ruclogin --debug
排除获取 cookies 阶段的问题。如果你无法解决这个问题,可以提交 Issue。尽量不要直接联系原作者,因为原作者已经不再更新脚本,发布在 Issue 中更有可能得到其他开发者的帮助。发起 Issue 时注意隐私,不要泄露自己的 Cookies。
抢别人后阶段退的课,实际上这种名额挺多的,我抢过:
- 社会主义500年
- 素质拓展
- 电影导论
- 后人类时代的全球影像
- 羽毛球
这些课最初的中签率都在 10% 到 30% 之间。
- 更新到更现代的 pyproject.toml
- 删除 --debug 选项,去掉默认情况下大部分错误捕获以方便调试(相当于默认开启 --debug)
- 显式指定了 courses.json 的编码,防止跨系统时默认编码不一致导致的问题
- 删除了对 simpleaudio 的默认安装要求,因为安装这个包很容易报错
- 更新到用 json 格式存储抓包
- 实时上传抢课次数
- 优化了提示信息
- 修复了不能正常访问 ruccourse.panjd.net 的问题
- 为了避免这个脚本产生过大的影响,默认分享网络请求次数到 ruccourse.panjd.net 用以追踪脚本被滥用的情况(不涉及个人账户信息),如果你对相关隐私有所顾虑,可以在配置文件中关闭或者退回到 0.1.5 版本,你可以到 RUC-CourseSelectionTool-stats 查看服务端源代码
- 修复不能正常自动结束的问题
- ruclogin 已经适配最新教务网站
- 添加新 errorCode 处理
- 添加了对未知 errorCode 的处理
- 添加了抢到课,或欲强课程有名额但同类名额到达上限时的声音提示功能,可以在配置文件中打开,默认关闭
- 增加了
--debug
参数,追踪报错信息