因为要考研嘛,想去图书馆。我们学校是早上六点开抢,同学们太猛,我每天5点50起床抢,都不太抢的到想要的座位,于是我就花了个两三天琢磨着怎么用代码来实现这个抢座,目前已经完成,虽然因为微信的那个sessid更新的比较频繁,还是需要早起来拿写好的安卓软件传个cookie的数据,但至少每天都能抢到固定的座位了,心情就很舒畅。

抢座原理的简述

{

‘Accept’: ‘application/json, text/javascript, */*; q=0.01’,

‘X-Requested-With’: ‘XMLHttpRequest’,

‘User-Agent’: ‘{随便找个手机抓个包扒拉下来放这就行}’,

‘Sec-Fetch-Mode’: ‘cors’,

‘Sec-Fetch-Site’: ‘same-origin’,

‘Referer’: ‘http://wechat.v2.traceint.com/index.php/reserve/layout/libid={所抢阅览室的id }.html&{所在学校的代码}’,

‘Accept-Encoding’: ‘gzip, deflate,br’,

‘Accept-Language’: ‘zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7’,

‘Cookie’: {实时抓包抓到的cookie值}

}

上面用大括 括起来的部分都是在应用中需要改变的部分,包括:

1、所抢阅览室的id ;

2、一段莫名其妙的编码;

3、该阅览室座位 对应的编码;

4、所在学校的代码;

5、实时抓包抓到的cookie值。

其中,1和4都是可以通过抓包轻而易举地得到的。关于抓包,学习起来难度很低,如果不会的小伙伴可以通过搜索一些文章轻松地完成学习。5是需要每天起早抓包得到并放入程序运行的内容,承载着用户信息,也很容易获取到。真正需要进行一些操作去获取的是2和3。将这些内容填入到get请求中,通过代码模拟手机发送get请求,就能够完成抢座。

获取座位 对应的编码

{显示的座位 }

知道了座位 和编码是如何映射的,只要从页面中爬取数据就可以了,代码如下所示。

from bs4 import BeautifulSoup

bs = BeautifulSoup(html, ‘html.parser’) #html是爬取到的 页的文本

zw = dict() #创建一个字典,用来存放座位 和编码的映射

div_tags = bs.find_all(‘div’, {‘class’: ‘grid_cell’})

for tag in div_tags:

zwid = tag.contents[1].string

if zwid != None and zwid != ‘窗’ and zwid != ‘柱’:

zw[zwid] = tag.get(‘data-key’)

通过这样一个映射的获取,我们就可以方便地通过座位 获取到其对应的编码了。

如何获取那一段莫名其妙的编码

在编写代码的过程中,我对抢座位这个过程进行的多次的抓包观察,发现在座位 前面的那个query字符串是一个看不出什么规律的编码。解析这个query是在后端进行解析,但既然发get请求你要在页面上发,那这个代码必然在前端是有迹可循的。这个编码的答案就在页面底部的js链接中,通过运行那一段js代码就可以搞定这个编码,从而拼凑起这最后一块拼图。

感谢各位能够看完这篇文章,如果有什么不理解的地方或者需要我的一些帮助,可以私信我

文章知识点与官方知识档案匹配,可进一步学习相关知识Java技能树首页概览91438 人正在系统学习中 相关资源:LibraryO:图书图书馆软件。-开源_图书馆开源项目-其它代码类资源…

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2021年2月1日
下一篇 2021年2月1日

相关推荐