文章插图
更多Python学习资料可以是私人关键词【资料】领取
除了t其他参数不变 , 感觉t就像一个随机数(因为考试 , 发现t保持不变也没关系) , 因为影响不大 , 我懒得继续分析了t到底是什么 , 把它想象成一个随机数(反正数字都一样16位) 。
OK , 仅此而已;那就到此为止 , 我们大概知道模拟登录的整个过程 , 然后开始写代码 , 同时进一步明确流程~首先是获得自然login_sig参数:
params = {'proxy_url': 'https://qzs.qq.com/qzone/v6/portal/proxy.html','daid': '5','hide_title_bar': '1','low_login': '0','qlogin_auto_login': '1','no_verifyimg': '1','link_target': 'blank','appid': '549000912','style': '22','target': 'self','s_url': 'https://qzs.qq.com/qzone/v5/loginsucc.html?para=izone','pt_qr_app': '手机QQ空间','pt_qr_link': 'https://z.qzone.com/download.html','self_regurl': 'https://qzs.qq.com/qzone/v6/reg/index.html','pt_qr_help_link': 'https://z.qzone.com/download.html','pt_no_auth': '0'}res = self.session.get(self.xlogin_url, headers=self.headers, verify=False, params=params)all_cookies.update(requests.utils.dict_from_cookiejar(res.cookies))pt_login_sig = all_cookies['pt_login_sig']复制代码
然后得到ptqrtoken参数:params = {'appid': '549000912','e': '2','l': 'M','s': '3','d': '72','v': '4','t': str(random.random()),'daid': '5','pt_3rd_aid': '0'}res = self.session.get(self.qrshow_url, headers=self.headers, verify=False, params=params)all_cookies.update(requests.utils.dict_from_cookiejar(res.cookies))ptqrtoken = self.__decryptQrsig(all_cookies['qrsig'])复制代码
同时 , 在请求上述链接的过程中 , 也就是:https://ssl.ptlogin2.qq.com/ptqrshow复制代码
我们还可以获取二维码图片(即res.content其实就是二维码的图像数据) , 并展示出来:saveImage(res.content, 'qrcode.jpg')showImage('qrcode.jpg')复制代码
然后我们通过不断请求我们一开始找到的二维码来登录链接 , 即:https://ssl.ptlogin2.qq.com/ptqrlogin复制代码
来检测QR码的当前状态:while True:params = {'u1': 'https://qzs.qq.com/qzone/v5/loginsucc.html?para=izone','ptqrtoken': ptqrtoken,'ptredirect': '0','h': '1','t': '1','g': '1','from_ui': '1','ptlang': '2052','action': '0-0-' + str(int(time.time())),'js_ver': '19112817','js_type': '1','login_sig': pt_login_sig,'pt_uistyle': '40','aid': '549000912','daid': '5','ptdrvs': 'AnyQUpMB2syC5zV6V4JDelrCvoAMh-HP6Xy5jvKJzHBIplMBK37jV1o3JjBWmY7j*U1eD8quewY_','has_onekey': '1'}res = self.session.get(self.qrlogin_url, headers=self.headers, verify=False, params=params)if '登录成功' in res.text:breakelif '二维码已过期' in res.text:raise RuntimeError('Fail to login, qrcode has expired...')time.sleep(2)复制代码
如果登录成功 , 用请求返回的链接更新session的cookies从而获得最终的QQ空间登录会话对象:all_cookies.update(requests.utils.dict_from_cookiejar(res.cookies))qq_number = re.findall(r'&uin=(.+?)&service', res.text)[0]print('[INFO]: Account -> %s, login successfully...' % qq_number)url_refresh = res.text[res.text.find('http'): res.text.find('pt_3rd_aid=0')] + 'pt_3rd_aid=0'self.session.cookies.update(all_cookies)res = self.session.get(url_refresh, allow_redirects=False, verify=False)all_cookies.update(requests.utils.dict_from_cookiejar(res.cookies))self.session.cookies.update(all_cookies)
END谢谢大家的支持和厚爱 , 小编每天都会分享更多Python为大家学习干货知识 , 所以别忘了关注小编哦 。
更多Python爬虫、数据分析、办公自动化、全栈开发、人工智能学习资源关键字【资料】领取
- 宝来和卡罗拉哪个车空间大、宝来和卡罗拉哪个耐用
- 试驾2022款沃尔沃V90,外观大气,空间实用
- linux查看正在登录的用户 linux查看系统关机原因
- 北京自主择业干部网 全国自主择业个人登录网址是什么
- 湖南省施工图管理信息系统登录 湖南省审图管理系统何军
- 国土空间规划三区三线内容是什么 乡镇国土空间规划主要内容
- 爱奇艺会员可同时登录几个设备 爱奇艺会员可以同时登录几个设备
- 什么游戏不用登录就能玩 免费又不用登录的游戏
- cf账号异地封号10年去哪申冤 cf异地登录封号10年怎么申诉
- 单位车二维码生成登陆平台