工具|python登录+验证码

方式一下载验证码到本地

# 通过登陆然后进入到主页面# 通过找登陆接口我们发现 登陆的时候需要的参数很多 # _VIEWSTATE: /m1O5dxmOo7f1qlmvtnyNyhhaUrWNVTs3TMKIsm1lvpIgs0WWWUCQHl5iMrvLlwnsqLUN6Wh1aNpitc4WnOt0So3k6UYdFyqCPI6jWSvC8yBA1Q39I7uuR4NjGo= # __VIEWSTATEGENERATOR: C93BE1AE # from: http://so.gushiwen.cn/user/collect.aspx # email: 595165358@qq.com # pwd: action # code: PId7 # denglu: 登录# 我们观察到_VIEWSTATE__VIEWSTATEGENERATORcode是一个可以变化的量# 难点:(1)_VIEWSTATE__VIEWSTATEGENERATOR一般情况看不到的数据 都是在页面的源码中 #我们观察到这两个数据在页面的源码中 所以我们需要获取页面的源码 然后进行解析就可以获取了 #(2)验证码import requests# 这是登陆页面的url地址 url = 'https://so.gushiwen.cn/user/login.aspx?from=http://so.gushiwen.cn/user/collect.aspx'headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36' }# 获取页面的源码 response = requests.get(url=url, headers=headers) content = response.text# 解析页面源码然后获取_VIEWSTATE__VIEWSTATEGENERATOR from bs4 import BeautifulSoupsoup = BeautifulSoup(content, 'lxml')# 获取_VIEWSTATE 页面隐藏域 viewstate = soup.select('#__VIEWSTATE')[0].attrs.get('value')# 获取__VIEWSTATEGENERATOR 页面隐藏域 viewstategenerator = soup.select('#__VIEWSTATEGENERATOR')[0].attrs.get('value')# 获取验证码图片 地址 code = soup.select('#imgCode')[0].attrs.get('src') code_url = 'https://so.gushiwen.cn' + code# 有坑 如果此处请求,会刷新登录页面验证码,拿到的验证码就已经失效 # import urllib.request # urllib.request.urlretrieve(url=code_url,filename='code.jpg') # requests里面有一个方法 session()通过session的返回值 就能使用请求变成一个对象session = requests.session() # 验证码的url的内容 response_code = session.get(code_url) # 注意此时要使用二进制数据因为我们要使用的是图片的下载 content_code = response_code.content # wb的模式就是将二进制数据写入到文件 with open('code.jpg', 'wb')as fp: fp.write(content_code)# 获取了验证码的图片之后 下载到本地 然后观察验证码观察之后 然后在控制台输入这个验证码 就可以将这个值给 # code的参数 就可以登陆code_name = input('请输入你的验证码')# 点击登陆 url_post = 'https://so.gushiwen.cn/user/login.aspx?from=http%3a%2f%2fso.gushiwen.cn%2fuser%2fcollect.aspx'data_post = { '__VIEWSTATE': viewstate, '__VIEWSTATEGENERATOR': viewstategenerator, 'from': 'http://so.gushiwen.cn/user/collect.aspx', 'email': '595165358@qq.com', 'pwd': 'action', 'code': code_name, 'denglu': '登录', }response_post = session.post(url=url, headers=headers, data=https://www.it610.com/article/data_post)content_post = response_post.textwith open('gushiwen.html', 'w', encoding=' utf-8')as fp: fp.write(content_post)# 难点 # (1) 隐藏域 # (2) 验证码

方式二 超级鹰 直接去 超级鹰 网站下载 demo ,切换一下图片路径直接使用
demo
#!/usr/bin/env python # coding:utf-8import requests from hashlib import md5class Chaojiying_Client(object):def __init__(self, username, password, soft_id): self.username = username password = password.encode('utf8') self.password = md5(password).hexdigest() self.soft_id = soft_id self.base_params = { 'user': self.username, 'pass2': self.password, 'softid': self.soft_id, } self.headers = { 'Connection': 'Keep-Alive', 'User-Agent': 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0)', }def PostPic(self, im, codetype): """ im: 图片字节 codetype: 题目类型 参考 http://www.chaojiying.com/price.html """ params = { 'codetype': codetype, } params.update(self.base_params) files = {'userfile': ('ccc.jpg', im)} r = requests.post('http://upload.chaojiying.net/Upload/Processing.php', data=https://www.it610.com/article/params, files=files, headers=self.headers) return r.json()def ReportError(self, im_id):""" im_id:报错题目的图片ID """ params = { 'id': im_id, } params.update(self.base_params) r = requests.post('http://upload.chaojiying.net/Upload/ReportError.php', data=https://www.it610.com/article/params, headers=self.headers) return r.json()if __name__ =='__main__': chaojiying = Chaojiying_Client('超级鹰用户名', '超级鹰用户名的密码', '96001')# 登录超级鹰>> 用户中心>>软件ID 生成一个替换 96001 im = open('a.jpg', 'rb').read()# 本地图片文件路径 来替换 a.jpg 有时WIN系统须要// print(chaojiying.PostPic(im, 1902))# 1902 验证码类型官方网站>>价格体系 3.4+版 print 后要加()

【工具|python登录+验证码】

    推荐阅读