加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
35_requests_cookie登陆古诗文网.py 2.56 KB
一键复制 编辑 原始数据 按行查看 历史
tom_glb 提交于 2021-09-21 16:50 . requests
import requests
from bs4 import BeautifulSoup
import urllib.request
# 通过找登陆接口我们发现 登陆的时候需要的参数很多
# _VIEWSTATE: /m1O5dxmOo7f1qlmvtnyNyhhaUrWNVTs3TMKIsm1lvpIgs0WWWUCQHl5iMrvLlwnsqLUN6Wh1aNpitc4WnOt0So3k6UYdFyqCPI6jWSvC8yBA1Q39I7uuR4NjGo=
# __VIEWSTATEGENERATOR: C93BE1AE
# from: http://so.gushiwen.cn/user/collect.aspx
# email: 595165358@qq.com
# pwd: action
# code: PId7
# denglu: 登录
# 我们观察到_VIEWSTATE __VIEWSTATEGENERATOR code是一个可以变化的量
# 难点:(1)_VIEWSTATE __VIEWSTATEGENERATOR 一般情况看不到的数据 都是在页面的源码中
# 我们观察到这两个数据在页面的源码中 所以我们需要获取页面的源码 然后进行解析就可以获取了
# (2)验证码
url = 'https://so.gushiwen.cn/user/login.aspx?from=http%3a%2f%2fso.gushiwen.cn%2fuser%2fcollect.aspx'
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Safari/537.36'
}
response = requests.get(url=url, headers=headers)
content = response.text
soup = BeautifulSoup(content, 'lxml')
# 获取__VIEWSTATE
viewState = soup.select('#__VIEWSTATE')[0].attrs.get('value')
# 获取__VIEWSTATEGENERATOR
viewStateGenerator = soup.select('#__VIEWSTATEGENERATOR')[0].attrs.get('value')
# 有坑
# code的参数 就可以登陆
# requests里面有一个方法 session() 通过session的返回值 就能使用请求变成一个对象
code_url = soup.select('#imgCode')[0].get('src')
code_url = 'https://so.gushiwen.cn' + code_url
# urllib.request.urlretrieve(code_url, 'code.png')
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)
fp.close()
# 获取了验证码的图片之后 下载到本地 然后观察验证码 观察之后 然后在控制台输入这个验证码 就可以将这个值给
code = input('请输入你的验证码:')
data = {
'__VIEWSTATE': viewState,
'__VIEWSTATEGENERATOR': viewStateGenerator,
'from': 'http://so.gushiwen.cn/user/collect.aspx',
'email': '595165358@qq.com',
'pwd': 'action',
'code': code,
'denglu': '登录'
}
response_login = session.post(url=url, data=data, headers=headers)
content_login = response_login.text
with open('gushiwen.html', 'w', encoding='utf-8') as fp:
fp.write(content_login)
fp.close()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化