• python获取cookie的方法


    介绍下3种获取cookie的方法。

    (1)借助handler

    这种方法也是网上介绍最多的一种方法,但是用起来比较麻

    from http import cookiejar
    from
    urllib import request class Craw(): def __init__(self): self.url = '' self.headers['User-Agent'] = 'Mozilla/5.0 (Windows NT 6.3; Win64; x64) ' 'AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.162 Safari/537.36' self.headers['Content-Type'] = 'application/x-www-form-urlencoded' def getCookies(self): cookie = cookiejar.CookieJar() handler = request.HTTPCookieProcessor(cookie) opener = request.build_opener(handler) response = opener.open(self.url) cookieValue = '' for item in cookie: cookieValue += item.name + '=' + item.value + ';' self.headers['Cookie'] = cookieValue response = requests.get(url=self.url) def getVerificationCode(self):
         img_url = ''
    imgResponse = requests.get(url=img_url,headers = self.headers) #直接使用headers即可 base64_jpg = base64.b64encode(imgResponse.content) return base64_jpg

    (2)使用response headers的set_cookie 

    import requests
    import re
    class Crawler():
      def getCookie(self):
         response = requests.post(self.url)
        set_cookie = response.headers['Set-Cookie']
        array = re.split('[;,]',set_cookie)
        cookieValue = ''
        for arr in array:
          if arr.find('DZSW_SESSIONID') >= 0 or arr.find('bl0gm1HBTB') >= 0:
            cookieValue += arr + ';'

    (3)使用response的cookies属性获取

    只写getCookies方法,代码如下:

    import requests    
    class Crawler():
        def getCookie(self):
            response = requests.get(self.url)
            cookie_value = ''
            for key,value in response.cookies.items():  
                cookie_value += key + '=' + value + ';'  
            self.headers['Cookie'] = cookie_value

    另外还有个疑问,就是response.cookies返回的是RequestsCookieJar对象,看到书上有这样的代码

    import requests
    class Crawl():
        def __init__(self):
            self.url = ''
            self.headers = {}
            self.cookieJar = requests.cookies.RequestsCookieJar()
        def getCookie()
            cookies = 'a=a1;b=b1' # 字符串
            for cookie in cookies.split(';'):
                key,value = cookie.split('=,1)
                self.cookieJar.set(key,value)
            r = requests.get(self.url,cookies = self.cookieJar,headers = self.headers)
    为什么不可以直接使用response.cookies赋值给最后请求的cookies。已尝试,结果报错,最后还是使用的方法2。

    希望熟悉的大神看到可以给予解答。

  • 相关阅读:
    Spring MVC-表单(Form)标签-单选按钮(RadioButton)示例(转载实践)
    Ubuntu 16.04中VirtualBox 5.1使用U盘/USB设备的方法
    Spring MVC-表单(Form)标签-复选框集合(Checkboxes)示例(转载实践)
    Ubuntu 16.04下减小/释放/清理VirtualBox虚拟硬盘文件的大小
    关注点分离
    谈代码注释
    DelegatingFilterProxy类的作用
    GOPS 2018全球运维大会上海站 参会感悟梳理
    Java switch case
    Android 微信网址分享添加网络图片
  • 原文地址:https://www.cnblogs.com/huhu-xiaomaomi/p/9884231.html
Copyright © 2020-2023  润新知