前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python scrapy 模拟登录(手动登录保存cookie)

python scrapy 模拟登录(手动登录保存cookie)

作者头像
用户5760343
发布2022-01-10 08:17:08
1.6K0
发布2022-01-10 08:17:08
举报
文章被收录于专栏:sktj

先登录网页,获取cookie,然后转化为字典,保存在settings.py中的COOKIES池中,使用中间件用cookie登录。

1、cookie,转化为字典 def cookieChangeToDict(cookie): ''' 将cookie字符串转换成字典 :param cookie: 登录后的cookie :return:字典 ''' cookieList = cookie.split(';') cookieDict = {} for cookie in cookieList: name = cookie.split('=', maxsplit=1)[0].strip() value = cookie.split('=', maxsplit=1)[1].strip() cookieDict[name] = value return cookieDict

if name == 'main': cookie = """ 你的cookie """ print(cookieChangeToDict(cookie))

把打印出的cookie放到settings.py中自定义的COOKIES=[]中

2、使用登录后的cookie发送请求 方式一:

可以重写Spider类的start_requests方法,附带Cookie值,发送POST请求

代码语言:javascript
复制
def start_requests(self):
    url= ''
    return [scrapy.FormRequest(url, cookies = self.cookies, callback = self.parse)]

方式2:使用中间件:

from scrapy import signals from scrapy.downloadermiddlewares.cookies import CookiesMiddleware import random

from renren.settings import COOKIES

class RandomCookieMiddleware(CookiesMiddleware): ''' 随机cookie池 ''' def process_request(self, request, spider): cookie = random.choice(COOKIES) request.cookies = cookie

在settings.py中设置:

ROBOTSTXT_OBEY = False

COOKIES_ENABLED = True

启用中间件

DOWNLOADER_MIDDLEWARES = { 'renren.middlewares.RandomCookieMiddleware': 543, }

COOKIES池

COOKIES = [ ]

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019.05.15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 把打印出的cookie放到settings.py中自定义的COOKIES=[]中
  • 可以重写Spider类的start_requests方法,附带Cookie值,发送POST请求
  • 启用中间件
  • COOKIES池
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档