完善代码在:抢课脚本
首先进入教务系统,按下F12键进入浏览器的开发者模式,输入账号、密码、验证码后进行抓包。通过抓包,可以发现几个接口:
登录接口:http://jwxt.xtu.edu.cn/jsxsd/xk/LoginToXk
获得验证码的接口:http://jwxt.xtu.edu.cn/jsxsd/verifycode.servlet
同时发现登录接口的参数是经过了加密的,它的参数如下:
USERNAME: 121
PASSWORD: 2342
encoded: 11G52wnj17%16%Rt%17220336w4o93295C
RANDOMCODE: fs
其中encoded明显是加密的数据。通过查找页面源码,我们发现它是通过一个js函数实现加密的。
这里先不细说了。完整部分在这里。
登录部分代码先不放置了,CSDN不给通过。具体可以看这里抢课脚本
具体步骤为:
选课部分没有什么难点,按下F12键找到相应的接口即可,但需要注意的是对课程进行搜索时,如果输入的是中文,接口部分的参数会是经过两次URL编码的值,即:
search_content = input('请输入课程名称:')
## 进行两次URL编码
search_content = urllib.parse.quote(search_content)
search_content = urllib.parse.quote(search_content)
print('编码信息:' + search_content)
该部分的代码为:
# 进入选课界面
choose_course_page_entry = session.get('http://jwxt.xtu.edu.cn/jsxsd/xsxk/xklc_list',headers=headers)
# print(choose_course_page_entry.text)
bs1 = BeautifulSoup(choose_course_page_entry.text,'html.parser')
# 找到选课的几个表格
choose_course_table = bs1.select('#tbKxkc tr')
## 删除第一个元素
choose_course_table.pop(0)
# print(len(choose_course_table))
choose_course_name = []
choose_course_link = []
print('选课中心内容展示如下:')
for line_tr in choose_course_table:
# print(line_tr)
name = line_tr.find_all('td')[1].text
course_link = line_tr.find_all('td')[3].find_all('a')[0]['href']
choose_course_link.append(host+course_link)
choose_course_name.append(name)
print(name + ":" + host + course_link)
number = eval(input('请进行你的选择:'))
course_page = session.get(choose_course_link[number-1],headers=headers)
if number == 1:
# 文化素质教育课程选课
wenhuasuzhi(session,header=headers)
elif number == 2:
kuaxiaogongxiang(session,header=headers)
print('暂未开发')
elif number == 3:
print('暂未开发')
elif number == 4:
print('暂未开发')
上面部分只是对抢课流程的一个大致介绍,还有一些细节等待完善,如:
需要注意的是,上面的代码只对文化素质教育课程选课部分进行了实现,其他部分没有实现。
后续会将完善的代码放在资源当中。