代码如下:(由于临时做的实例采用登录云打码平台的cookies)
import requests from lxml.html import etree from fake_useragent import UserAgent from http.cookiejar import LWPCookieJar from ydm import shibie session = requests.Session() session.cookies = LWPCookieJar(filename='ydm.txt') try: session.cookies.load('ydm.txt', ignore_discard=True, ignore_expires=True) print('本地cookie加载完成') except Exception as e: print('') ua = UserAgent() headers = { 'headers': ua.random, } def get_captcha_image(): content = session.get('http://www.yundama.com/index/captcha', headers=headers).content with open('captcha.jpg', 'wb') as f: f.write(content) def login(): get_captcha_image() # 验证码保存到本地以后,对验证码进行识别 result = shibie('captcha.jpg') print('识别结果:', result) response = session.get('http://www.yundama.com/index/login?username=gaohairui&password=gao12345&utype=1&vcode={}'.format(result)) print(response.text) session.cookies.save(ignore_discard=True, ignore_expires=True) if __name__ == '__main__': login()
不难看出最后的保存的两个参数:ignore_discard和ignore_expires
session.cookies.save(ignore_discard=True, ignore_expires=True)
两个参数的作用:
官方的解释:
ignore_discard: save even cookies set to be discarded.
ignore_expires: save even cookies that have expired.The file is overwritten if it already exists
不难看出两个参数的实际作用是:ignore_discard的意思是即使cookies将被丢弃也将它保存下来,ignore_expires的意思 是如果cookies已经过期也将它保存并且文件已存在时将覆盖,在这里,我们将这两个全部设置为True。运行之后,cookies 将被保存到ydm.txt文件中。
查看一下内容: