Skip to content

Releases: YinMo19/hit_course

v0.5

03 Jan 07:02
Compare
Choose a tag to compare

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 学年......

V0.4

29 Dec 15:24
Compare
Choose a tag to compare

HITSZ 抢课小脚本

YinMo19

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

使用方法

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

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

hit_course

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

all_courses/<your courses>.json

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

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

26 Dec 07:08
Compare
Choose a tag to compare

HITSZ 抢课小脚本

YinMo19

请注意!可能没用

可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是

hit_course
req_auth

hit_course

这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。

使用 hit_course 需要提前准备课程的文件,放在 all_courses下面

all_courses/<your courses>.json

可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
browser
然后将命令粘贴到命令行,追加 > 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

25 Dec 14:29
Compare
Choose a tag to compare

HITSZ 抢课小脚本

YinMo19

请注意!可能没用

可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是

hit_course
req_auth

hit_course

这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。

使用 hit_course 需要提前准备两个文件

must.json
pe.json

可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
browser
然后将命令粘贴到命令行,追加 > 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

24 Dec 13:36
4c16819
Compare
Choose a tag to compare

HITSZ 抢课小脚本

YinMo19

请注意!可能没用

可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是

hit_course
req_auth

hit_course

这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。

使用 hit_course 需要提前准备两个文件

must.json
pe.json

可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
browser
然后将命令粘贴到命令行,追加 > 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

23 Dec 19:57
Compare
Choose a tag to compare

HITSZ 抢课小脚本

YinMo19

请注意!可能没用

可以在 release 选择你的系统,下载的压缩包里面有两个可执行文件,分别是

hit_course
req_auth

hit_course

这两个分别是提前准备好课程信息和cookie,直接对应请求,而第二个是直接从头开始走一遍验证。

使用 hit_course 需要提前准备两个文件

must.json
pe.json

可以直接在浏览器中打开 f12 ,选中网络,然后点击必修课程,能够看到一条请求。将这条请求复制位 cURL
browser
然后将命令粘贴到命令行,追加 > 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

23 Dec 19:36
Compare
Choose a tag to compare

use the req_auth, the hit_course is bad.