Releases: YinMo19/hit_course
v0.5
HITSZ 抢课小脚本
YinMo19
请注意!由于神秘的教务系统,本脚本可能没用。
使用方法
在本仓库的 Releases 中选择对应系统的文件进行下载,下载得到的压缩包里面有两个可执行文件,分别是 hit_course
和 req_auth
。
hit_course
需提前准备好课程信息和 cookie,直接对应请求进行选课;而 req_auth
则是直接请求鉴权,通过本研账号和密码从头开始走一遍验证,然后选课。
准备工作
使用 hit_course
需要提前准备课程的 .json
文件,放在 all_courses
文件夹内,例如:
all_courses/<your courses>.json
课程 .json
文件的获取方式:
可以直接在浏览器中打开 f12
,选中 网络
,然后点击必修课程(或其他课程),点击选课后能够看到一条请求。将这条请求复制为 cURL
:
然后将命令粘贴到命令行,追加 > <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 学年......
V0.4
HITSZ 抢课小脚本
YinMo19
请注意!由于神秘的教务系统,本脚本可能没用。
使用方法
在本仓库的 Releases 中选择对应系统的文件进行下载,下载得到的压缩包里面有两个可执行文件,分别是 hit_course
和 req_auth
。
hit_course
需提前准备好课程信息和 cookie,直接对应请求进行选课;而 req_auth
则是直接请求鉴权,通过本研账号和密码从头开始走一遍验证,然后选课。
hit_course
使用 hit_course
需要提前准备课程的 .json
文件,放在 all_courses
文件夹内,例如:
all_courses/<your courses>.json
课程 .json
文件的获取方式:
可以直接在浏览器中打开 f12
,选中 网络
,然后点击必修课程(或其他课程),点击选课后能够看到一条请求。将这条请求复制为 cURL
:
然后将命令粘贴到命令行,追加 > <your courses>.json
,例如:
就可以将课程信息写入一个 .json
文件了。之后将这个 .json
文件放到 all_courses 下面即可。
说明:若未到选课时间,选课按钮为灰色,则按 f12
打开控制台,右键选课的按钮,选择“检查”找到对应的代码位置,删掉 disabled
相关的代码,按钮即可变为可点击的状态。然后再次点击选课按钮,即可在 网络
中看到对应的请求。
hit_course
使用方法:
复制你的 cookie
(可以从上面复制的命令请求头里面找到),用双引号引出,然后使用:
./hit_course --cookie <your cookie>
就可以开始选择你要抢的课了,例如(windows):
.\hit_course.exe -c "route=<your route>; JSESSIONID=<your JSESSIONID>"
需要注意的是,推荐在抢课前提前将上述导入课程 .json
的步骤做好,否则在抢课的时候你可能甚至没法登陆看到这些课程的内容。
所以什么是 cookie?为什么程序拿到 cookie 可以帮你抢课?安全吗?你可以查询一下 cookie/session 相关知识了解。
可能会遇到的问题有:教务抽风导致的各种 session 失效。教务抽风导致的返回值 null, 教务抽风导致的 ......
req_auth
这个程序直接请求鉴权,通过本研账号和密码从头开始走一遍验证,使用会简单一些,但是对于抢课高峰期时鉴权死掉的系统就没啥用了(经过尝试,在抢课高峰期官网登不上时本程序有更大的可能性成果登上,所以可以一试)。
直接在命令行输入:
./req_auth -h
就能看到帮助文档,简单易用。使用方法为:
./req_auth -u <your username> -p <your password>
需要注意,req auth也需要你提前准备好 json
文件,方法和上述一样。只不过现在不需要你手动准备 cookie,而是给账号密码自动走一遍登陆流程。
自己构建
使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为:
cargo build --release
cargo build --example req_auth --release
如果用不了,可以考虑去源码中更改对应的请求体,因为教务本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂,所以基本上就是替换关键字,如果还有不一样的可以自行修改。(可能不需要你本地构建,开一个新仓库推上去,我写好了 ci,github会帮你构建)
TODO:
需要注意的小问题:因为事实上就是没法看懂请求体的具体内容,所以我没法做通用的。如果我还在更新那没事,如果没有更新,可以考虑参考上面获取课程json的方法,看看curl请求体里面的body,更新一些,例如 2024-2025学年......
V0.3
HITSZ 抢课小脚本
YinMo19
请注意!可能没用
可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是
hit_course
req_auth
hit_course
这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。
使用 hit_course 需要提前准备课程的文件,放在 all_courses下面
all_courses/<your courses>.json
可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
然后将命令粘贴到命令行,追加 > must.json
,例如
就可以写入一个json文件了。将这个json文件放到 all_courses 下面。接下来复制你的cookie(可以从上面复制的命令里面找到),然后使用
./hit_course --cookie <your cookie>
就可以开始选择你要抢的课了。
需要注意的是,推荐在抢课前提前将导入 json 的步骤做好,否则在抢课的时候你可能甚至没法登陆看到这些课程的内容。
req_auth
这个使用会简单一些,但是对于鉴权死掉的系统就没啥用了。直接在命令行输入
./req_auth -h
就能看到帮助文档,简单易用。
自己构建
使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为
cargo build --release
cargo build --example req_auth --release
如果用不了了,可以考虑去源码中更改对应的请求体,因为本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂所以基本上就是替换关键词。
V0.2.1
HITSZ 抢课小脚本
YinMo19
请注意!可能没用
可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是
hit_course
req_auth
hit_course
这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。
使用 hit_course 需要提前准备两个文件
must.json
pe.json
可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
然后将命令粘贴到命令行,追加 > must.json
,例如
就可以写入一个json文件了。pe.json
也是一样的,将别的课程(例如跨专业/体育课)的课程使用同样的方法将 json 导入 pe.json
,那么就可以以相同的方法选课。
接下来复制你的cookie,然后使用
./hit_course --cookie <your cookie>
就可以开始选择你要抢的课了。
需要注意的是,推荐在抢课前提前将导入 json 的步骤做好,否则在抢课的时候你可能甚至没法登陆看到这些课程的内容。
req_auth
这个使用会简单一些,但是对于鉴权死掉的系统就没啥用了。直接在命令行输入
./req_auth -h
就能看到帮助文档,简单易用。
自己构建
使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为
cargo build --release
cargo build --example req_auth --release
如果用不了了,可以考虑去源码中更改对应的请求体,因为本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂所以基本上就是替换关键词。
V0.2
HITSZ 抢课小脚本
YinMo19
请注意!可能没用
可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是
hit_course
req_auth
hit_course
这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。
使用 hit_course 需要提前准备两个文件
must.json
pe.json
可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
然后将命令粘贴到命令行,追加 > must.json
,例如
就可以写入一个json文件了。
接下来复制你的cookie,然后使用
./hit_course --cookie <your cookie>
就可以开始选择你要抢的课了。
req_auth
这个使用会简单一些,但是对于鉴权死掉的系统就没啥用了。直接在命令行输入
./req_auth -h
就能看到帮助文档,简单易用。
自己构建
使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为
cargo build --release
cargo build --example req_auth --release
如果用不了了,可以考虑去源码中更改对应的请求体,因为本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂所以基本上就是替换关键词。
V0.1
HITSZ 抢课小脚本
YinMo19
请注意!可能没用
可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是
hit_course
req_auth
hit_course
这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。
使用 hit_course 需要提前准备两个文件
must.json
pe.json
可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
然后将命令粘贴到命令行,追加 > must.json
,例如
就可以写入一个json文件了。
接下来复制你的cookie,然后使用
./hit_course --cookie <your cookie>
就可以开始选择你要抢的课了。
req_auth
这个使用会简单一些,但是对于鉴权死掉的系统就没啥用了。直接在命令行输入
./req_auth -h
就能看到帮助文档,简单易用。
自己构建
使用 rust 编写,在 linux 系统上可能需要安装 openssl 依赖。关于如何安装 rust 环境这里不多说,构建方法为
cargo build --release
cargo build --example req_auth --release
如果用不了了,可以考虑去源码中更改对应的请求体,因为本身请求体非常丑陋(全都是不明所以的拼音缩写),我看不懂所以基本上就是替换关键词。
V0.0.1
use the req_auth, the hit_course is bad.