好好玩吧 2019-06-10 21:30 采纳率: 66.7%
浏览 1563
已采纳

如何在scrapy中带cookie访问?

看到网上的方法是发起Request请求时,带上meta={'cookiejar':1},但是我按这个方法操作,并没有带上cookie啊,print的时候cookie是空的,具体应该怎么实现呢?

  • 写回答

2条回答 默认 最新

  • Next66 2019-06-11 11:42
    关注
    import scrapy
    from scrapy.http import Request, FormRequest
    
    
    class PachSpider(scrapy.Spider):  # 定义爬虫类,必须继承scrapy.Spider
        name = 'pach'  # 设置爬虫名称
        allowed_domains = ['edu.iqianyue.com']  # 爬取域名
    
        header = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:54.0) Gecko/20100101 Firefox/54.0'}
    
        def start_requests(self):  # 用start_requests()方法,代替start_urls
            """第一次请求一下登录页面,设置开启cookie使其得到cookie,设置回调函数"""
            return [Request('http://edu.iqianyue.com/index_user_login.html', meta={'cookiejar': 1}, callback=self.parse)]
    
        def parse(self, response):  # parse回调函数
    
            data = {  # 设置用户登录信息,对应抓包得到字段
                'number': '****',
                'passwd': '****',
                'submit': ''
            }
    
            # 响应Cookie
            # 查看一下响应Cookie,也就是第一次访问注册页面时后台写入浏览器的Cookie
            Cookie1 = response.headers.getlist('Set-Cookie')
            print(Cookie1)
    
            print('登录中')
            """第二次用表单post请求,携带Cookie、浏览器代理、用户登录信息,进行登录给Cookie授权"""
            return [FormRequest.from_response(response,
                                              url='http://edu.iqianyue.com/index_user_login',  # 真实post地址
                                              meta={
                                                  'cookiejar': response.meta['cookiejar']},
                                              headers=self.header,
                                              formdata=data,
                                              callback=self.next,
                                              )]
    
        def next(self, response):
            a = response.body.decode("utf-8")  # 登录后可以查看一下登录响应信息
            # print(a)
            """登录后请求需要登录才能查看的页面,如个人中心,携带授权后的Cookie请求"""
            yield Request('http://edu.iqianyue.com/index_user_index.html', meta={'cookiejar': True}, callback=self.next2)
    
        def next2(self, response):
            # 请求Cookie
            Cookie2 = response.request.headers.getlist('Cookie')
            print(Cookie2)
    
            body = response.body  # 获取网页内容字节类型
            unicode_body = response.body_as_unicode()  # 获取网站内容字符串类型
    
            a = response.xpath('/html/head/title/text()').extract()  # 得到个人中心页面
            print(a)
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵