Skip to content

Latest commit

 

History

History
96 lines (63 loc) · 4.32 KB

README.md

File metadata and controls

96 lines (63 loc) · 4.32 KB

HITSZ 抢课小脚本

YinMo19

请注意!由于神秘的教务系统,本脚本可能没用。

使用方法

在本仓库的 Releases 中选择对应系统的文件进行下载,下载得到的压缩包里面有两个可执行文件,分别是 hit_coursereq_auth

hit_course 需提前准备好课程信息和 cookie,直接对应请求进行选课;而 req_auth 则是直接请求鉴权,通过本研账号和密码从头开始走一遍验证,然后选课。

准备工作

使用 hit_course 需要提前准备课程的 .json 文件,放在 all_courses 文件夹内,例如:

all_courses/<your courses>.json

课程 .json 文件的获取方式:

可以直接在浏览器中打开 f12 ,选中 网络,然后点击必修课程(或其他课程),点击选课后能够看到一条请求。将这条请求复制为 cURL: browser 然后将命令粘贴到命令行,追加 > <your courses>.json,例如:

就可以将课程信息写入一个 .json 文件了。之后将这个 .json 文件放到 all_courses 下面即可。

说明:若未到选课时间,选课按钮为灰色,则按 f12 打开控制台,右键选课的按钮,选择“检查”找到对应的代码位置,删掉 disabled 相关的代码,按钮即可变为可点击的状态。然后再次点击选课按钮,即可在 网络 中看到对应的请求。

req_auth

这个程序直接请求鉴权,通过本研账号和密码从头开始走一遍验证,使用会更简单一些。经过尝试,在抢课高峰期官网登不上时本程序有更大的可能性成果登上,所以可以一试。

直接在命令行输入:

./req_auth -h

就能看到帮助文档

Usage: req_auth [OPTIONS] --username <USERNAME> --password <PASSWORD>

Options:
  -u, --username <USERNAME>        用户名
  -p, --password <PASSWORD>        密码
  -s, --selected-json              默认从文件夹中读取 JSON(的课程信息)。 如果加上此参数(eg. './req_auth -s') 则会从当前目录读 `pre_select.json`进行直接选课。
  -f, --folder-addr <FOLDER_ADDR>  存放json 的文件夹地址,默认 all_courses
  -h, --help                       Print help
  -V, --version                    Print version

,简单易用。使用方法为:

./req_auth -u <your username> -p <your password>

需要注意的是,推荐在抢课前提前将上述导入课程 .json 的步骤做好,否则在抢课的时候你可能甚至没法登陆看到这些课程的内容。

hit_course

hit_course 使用方法:

复制你的 cookie(可以从上面复制的命令请求头里面找到),用双引号引出,然后使用:

./hit_course --cookie <your cookie>

就可以开始选择你要抢的课了,例如(windows):

.\hit_course.exe -c "route=<your route>; JSESSIONID=<your JSESSIONID>"

在windows下面的运行二进制可能是.\而非./,但这又取决于你用的是什么终端。在 MacOS 和 Linux 下都是 ./

所以什么是 cookie?为什么程序拿到 cookie 可以帮你抢课?安全吗?你可以查询一下 cookie/session 相关知识了解。

可能会遇到的问题有:教务抽风导致的各种 session 失效。教务抽风导致的返回值 null, 教务抽风导致的 ......

自己构建

使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为:

cargo build --release
cargo build --example req_auth --release

如果用不了,可以考虑去源码中更改对应的请求体,因为教务本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂,所以基本上就是替换关键字,如果还有不一样的可以自行修改。(可能不需要你本地构建,开一个新仓库推上去,我写好了 ci,github 会帮你构建)

TODO:

需要注意的小问题:因为事实上就是没法看懂请求体的具体内容,所以我没法做通用的。如果我还在更新那没事,如果没有更新,可以考虑参考上面获取课程 json 的方法,看看 curl 请求体里面的 body,更新一些,例如 2024-2025 学年......