脚本功能
系统开放座位时快速预约指定位置
可以设置预约的时间段
运行以后会一直帮你抢,需要手动停止
即使遇到更强的脚本自动帮抢下一个座位
实现
首先解决登录问题,通过F12找出登录请求包,分析对比一下包可以发现一般只有用户名和密码这个参数是变化的,然后用requests.session()的实例化去请求登录接口,登录成功。
然后预约座位抓一下包,分析包找到变化的关键的参数,一般情况下关键参数只有座位id、开始时间、结束时间,其他的参数一股脑照搬就行了,接下来用刚刚登录成功的那个requests.session()实例去请求即可。
优化
既然是每天都帮抢那么一直去请求可不行,一是给服务器造成负担,二是如果有什么反爬策略容易被发现被封。所以每天到12点(系统预约开放时间)的时候发预约包就行。
万一脚本撞车了没抢到自己设定的座位怎么办,返回预约的结果,发现已经有人了自动预约下一个座位,也可以将自己心仪的座位写在列表里,这个抢不到抢下一个。
代码
(为了不给学校系统添加负担,代码仅供参考,无法直接运行)
import requests from datetime import date from datetime import timedelta import json import getopt import sys import time global headers headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:80.0) Gecko/20100101 Firefox/80.0', 'Host': '', } #登录函数 def login(id, pwd): l_params = { 'id': id, 'pwd': pwd, 'act': 'login', } #自己分析得到的接口,下同 login_url = '' s = requests.session() re = s.post(url=login_url, headers=headers, params=l_params) #返回登录成功的实例 return s #预约函数 def yd(s, start, end, s_id): y_params = { "dialogid": "", #预定座位 "dev_id": s_id, "room_id":"", "type":"dev", "prop":"", "number":"", "classkind":"", "test_name":"", "start": start, "end": end, "start_time": "800", "end_time": "2200", } y_url = '' re = s.get(url=y_url, headers=headers, params=y_params) print(re.text) res = json.loads(re.text) msg = res['msg'] if msg == '操作成功!': print('success') return 1 elif msg == '2020-09-11只能提前[1]天预约': return 0 else: print('fail') return 2 #脚本输入提示信息 def useage(): print( ''' Usage: -i 学号(必填) -p 密码 -s 座位id -b 开始时间,格式13:00,下同 -e 结束时间 ''') if __name__ == '__main__': id = pwd = None #不填默认抢这个这个时间段的这个座位 s_id = '100458282' begin = '8:00' end = '22:00' #处理输入 try: opts, args = getopt.getopt(sys.argv[1:], 'i:p:s:b:e:') for name, value in opts: if name == '-i': id = value if name == '-p': pwd = value if name == '-s': s_id = value if name == '-b': begin = value if name == '-e': end = value except getopt.GetoptError: useage() if not id: useage() sys.exit(3) if not pwd: pwd = id #先获取后天时间 aftertomorrow = date.isoformat(date.today() + timedelta(days=2)) while True: hour = int(time.strftime('%H',time.localtime(time.time()))) m = int(time.strftime('%M', time.localtime(time.time()))) #如果现在的明天等与之前的后天,即到了12点,开始抢座 if date.isoformat(date.today() + timedelta(days=1)) == aftertomorrow: s = login(id, pwd) start = aftertomorrow + ' ' + begin endtime = aftertomorrow + ' ' + end result = yd(s, start, endtime, s_id) if result == 1: #预约成功 aftertomorrow = date.isoformat(date.today() + timedelta(days=2)) sleep_time = (23 - hour) * 3600 + (59 - m) * 60 + 35 print('程序休眠{}s'.format(sleep_time)) print(aftertomorrow) time.sleep(sleep_time) elif result == 2: #被预约,抢下一个id的座位 s_id = str(int(s_id) - 1) continue else: continue else: sleep_time = (23 - hour) * 3600 + (59 - m) * 60 time.sleep(sleep_time)
结语
不知道你们的学校图书馆预约系统是什么样的,但是一般学校也不会花太多钱去搞这个,所以系统比较垃圾,大部分可以按照这个思路来。而且有些学校跟我们学校用的几乎相同的系统,肯定是出自同一个公司或者同一个模板的。如果你们学校也是类似的系统,代码改一下就能用。
我学校的系统主页大概长这样
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]