设置下载中间件(Downloader Middlewares)

下载中间件是处于引擎(crawler.engine)和下载器(crawler.engine.download())之间的一层组件,可以有多个下载中间件被加载运行。

  1. 当引擎传递请求给下载器的过程中,下载中间件可以对请求进行处理 (例如增加http header信息,增加proxy信息等);

  2. 在下载器完成http请求,传递响应给引擎的过程中, 下载中间件可以对响应进行处理(例如进行gzip的解压等)

要激活下载器中间件组件,将其加入到 DOWNLOADER_MIDDLEWARES 设置中。 该设置是一个字典(dict),键为中间件类的路径,值为其中间件的顺序(order)。

  1. DOWNLOADER_MIDDLEWARES = {
  2. 'mySpider.middlewares.MyDownloaderMiddleware': 543,
  3. }

编写下载器中间件十分简单。每个中间件组件是一个定义了以下一个或多个方法的Python类:

  1. class scrapy.contrib.downloadermiddleware.DownloaderMiddleware

process_request(self, request, spider)

  • 当每个request通过下载中间件时,该方法被调用。

  • process_request() 必须返回以下其中之一:一个 None 、一个 Response 对象、一个 Request 对象或 raise IgnoreRequest:

    • 如果其返回 None ,Scrapy将继续处理该request,执行其他的中间件的相应方法,直到合适的下载器处理函数(download handler)被调用, 该request被执行(其response被下载)。

    • 如果其返回 Response 对象,Scrapy将不会调用 任何 其他的 process_request() 或 process_exception() 方法,或相应地下载函数; 其将返回该response。 已安装的中间件的 process_response() 方法则会在每个response返回时被调用。

    • 如果其返回 Request 对象,Scrapy则停止调用 process_request方法并重新调度返回的request。当新返回的request被执行后, 相应地中间件链将会根据下载的response被调用。

    • 如果其raise一个 IgnoreRequest 异常,则安装的下载中间件的 process_exception() 方法会被调用。如果没有任何一个方法处理该异常, 则request的errback(Request.errback)方法会被调用。如果没有代码处理抛出的异常, 则该异常被忽略且不记录(不同于其他异常那样)。

  • 参数:

    • request (Request 对象) – 处理的request
    • spider (Spider 对象) – 该request对应的spider

process_response(self, request, response, spider)

当下载器完成http请求,传递响应给引擎的时候调用

  • process_request() 必须返回以下其中之一: 返回一个 Response 对象、 返回一个 Request 对象或raise一个 IgnoreRequest 异常。

    • 如果其返回一个 Response (可以与传入的response相同,也可以是全新的对象), 该response会被在链中的其他中间件的 process_response() 方法处理。

    • 如果其返回一个 Request 对象,则中间件链停止, 返回的request会被重新调度下载。处理类似于 process_request() 返回request所做的那样。

    • 如果其抛出一个 IgnoreRequest 异常,则调用request的errback(Request.errback)。 如果没有代码处理抛出的异常,则该异常被忽略且不记录(不同于其他异常那样)。

  • 参数:

    • request (Request 对象) – response所对应的request
    • response (Response 对象) – 被处理的response
    • spider (Spider 对象) – response所对应的spider

实例

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. import random
  5. import base64
  6.  
  7. from settings import USER_AGENTS
  8. from settings import PROXIES
  9.  
  10. # 随机的User-Agent
  11. class RandomUserAgent(object):
  12. def process_request(self, request, spider):
  13. useragent = random.choice(USER_AGENTS)
  14.  
  15. request.headers.setdefault("User-Agent", useragent)
  16.  
  17. class RandomProxy(object):
  18. def process_request(self, request, spider):
  19. proxy = random.choice(PROXIES)
  20.  
  21. if proxy['user_passwd'] is None:
  22. # 没有代理账户验证的代理使用方式
  23. request.meta['proxy'] = "http://" + proxy['ip_port']
  24. else:
  25. # 对账户密码进行base64编码转换
  26. base64_userpasswd = base64.b64encode(proxy['user_passwd'])
  27. # 对应到代理服务器的信令格式里
  28. request.headers['Proxy-Authorization'] = 'Basic ' + base64_userpasswd
  29. request.meta['proxy'] = "http://" + proxy['ip_port']

为什么HTTP代理要使用base64编码:

HTTP代理的原理很简单,就是通过HTTP协议与代理服务器建立连接,协议信令中包含要连接到的远程主机的IP和端口号,如果有需要身份验证的话还需要加上授权信息,服务器收到信令后首先进行身份验证,通过后便与远程主机建立连接,连接成功之后会返回给客户端200,表示验证通过,就这么简单,下面是具体的信令格式:

修改settings.py配置USER_AGENTS和PROXIES

添加USER_AGENTS:

  1.  USER_AGENTS = [
  2. "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET CLR 2.0.50727; Media Center PC 6.0)",
  3. "Mozilla/5.0 (X11; U; Linux; en-US) AppleWebKit/527+ (KHTML, like Gecko, Safari/419.3) Arora/0.6",
  4. "Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9) Gecko/20080705 Firefox/3.0 Kapiko/3.0",
  5. ]

添加代理IP设置PROXIES:

  1. PROXIES = [
  2. {'ip_port': 'ip:port1', 'user_passwd': 'user1:pass1'},
  3. {'ip_port': 'ip2:port2', 'user_passwd': 'user2:pass2'},
  4. {'ip_port': 'ip3:port3', 'user_passwd': 'user3:pass3'},
  5. ]

除非特殊需要,禁用cookies,防止某些网站根据Cookie来封锁爬虫。

  1. COOKIES_ENABLED = False

设置下载延迟

  1. DOWNLOAD_DELAY = 3

最后添加自己写的下载中间件类

  1. DOWNLOADER_MIDDLEWARES = {
  2. 'mySpider.middlewares.MyDownloaderMiddleware': 543,
  3. }
  1. BOT_NAME
  2.  
  3. 默认: 'scrapybot'
  4.  
  5. 当您使用 startproject 命令创建项目时其也被自动赋值。
  6.  
  7. CONCURRENT_ITEMS
  8.  
  9. 默认: 100
  10.  
  11. Item Processor(即 Item Pipeline) 同时处理(每个response的)item的最大值。
  12.  
  13. CONCURRENT_REQUESTS
  14. 默认: 16
  15.  
  16. Scrapy downloader 并发请求(concurrent requests)的最大值。
  17.  
  18. DEFAULT_REQUEST_HEADERS
  19. 默认: 如下
  20.  
  21. {
  22. 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
  23. 'Accept-Language': 'en',
  24. }
  25. Scrapy HTTP Request使用的默认header
  26.  
  27. DEPTH_LIMIT
  28.  
  29. 默认: 0
  30.  
  31. 爬取网站最大允许的深度(depth)值。如果为0,则没有限制。
  32.  
  33. DOWNLOAD_DELAY
  34. 默认: 0
  35.  
  36. 下载器在下载同一个网站下一个页面前需要等待的时间。该选项可以用来限制爬取速度, 减轻服务器压力。同时也支持小数:
  37.  
  38. DOWNLOAD_DELAY = 0.25 # 250 ms of delay
  39.  
  40. 默认情况下,Scrapy在两个请求间不等待一个固定的值, 而是使用0.51.5之间的一个随机值 * DOWNLOAD_DELAY 的结果作为等待间隔。
  41. DOWNLOAD_TIMEOUT
  42.  
  43. 默认: 180
  44.  
  45. 下载器超时时间(单位: 秒)。
  46.  
  47. ITEM_PIPELINES
  48. 默认: {}
  49.  
  50. 保存项目中启用的pipeline及其顺序的字典。该字典默认为空,值(value)任意,不过值(value)习惯设置在0-1000范围内,值越小优先级越高。
  51.  
  52. ITEM_PIPELINES = {
  53. 'mySpider.pipelines.SomethingPipeline': 300,
  54. 'mySpider.pipelines.ItcastJsonPipeline': 800,
  55. }
  56. LOG_ENABLED
  57.  
  58. 默认: True
  59.  
  60. 是否启用logging
  61.  
  62. LOG_ENCODING
  63.  
  64. 默认: 'utf-8'
  65.  
  66. logging使用的编码。
  67.  
  68. LOG_LEVEL
  69.  
  70. 默认: 'DEBUG'
  71.  
  72. log的最低级别。可选的级别有: CRITICAL ERRORWARNINGINFODEBUG
  73.  
  74. USER_AGENT
  75. 默认: "Scrapy/VERSION (+http://scrapy.org)"
  76.  
  77. 爬取的默认User-Agent,除非被覆盖。
  78.  
  79. PROXIES 代理设置
  80. 示例:
  81.  
  82. PROXIES = [
  83. {'ip_port': '111.11.228.75:80', 'password': ''},
  84. {'ip_port': '120.198.243.22:80', 'password': ''},
  85. {'ip_port': '111.8.60.9:8123', 'password': ''},
  86. {'ip_port': '101.71.27.120:80', 'password': ''},
  87. {'ip_port': '122.96.59.104:80', 'password': ''},
  88. {'ip_port': '122.224.249.122:8088', 'password':''},
  89. ]
  90. COOKIES_ENABLED = False
  91. 禁用Cookies

所有settings介绍

python爬虫人门(10)Scrapy框架之Downloader Middlewares的更多相关文章

  1. Python爬虫进阶三之Scrapy框架安装配置

    初级的爬虫我们利用urllib和urllib2库以及正则表达式就可以完成了,不过还有更加强大的工具,爬虫框架Scrapy,这安装过程也是煞费苦心哪,在此整理如下. Windows 平台: 我的系统是 ...

  2. python爬虫(4)——scrapy框架

    安装 urllib库更适合写爬虫文件,scrapy更适合做爬虫项目. 步骤: 先更改pip源,国外的太慢了,参考:https://www.jb51.net/article/159167.htm 升级p ...

  3. Python爬虫教程-31-创建 Scrapy 爬虫框架项目

    本篇是介绍在 Anaconda 环境下,创建 Scrapy 爬虫框架项目的步骤,且介绍比较详细 Python爬虫教程-31-创建 Scrapy 爬虫框架项目 首先说一下,本篇是在 Anaconda 环 ...

  4. python网络爬虫(2)——scrapy框架的基础使用

    这里写一下爬虫大概的步骤,主要是自己巩固一下知识,顺便复习一下. 一,网络爬虫的步骤 1,创建一个工程 scrapy startproject 工程名称 创建好工程后,目录结构大概如下: 其中: sc ...

  5. 爬虫(9) - Scrapy框架(1) | Scrapy 异步网络爬虫框架

    什么是Scrapy 基于Twisted的异步处理框架 纯python实现的爬虫框架 基本结构:5+2框架,5个组件,2个中间件 5个组件: Scrapy Engine:引擎,负责其他部件通信 进行信号 ...

  6. python爬虫实战:利用scrapy,短短50行代码下载整站短视频

    近日,有朋友向我求助一件小事儿,他在一个短视频app上看到一个好玩儿的段子,想下载下来,可死活找不到下载的方法.这忙我得帮,少不得就抓包分析了一下这个app,找到了视频的下载链接,帮他解决了这个小问题 ...

  7. Python3爬虫(十七) Scrapy框架(一)

    Infi-chu: http://www.cnblogs.com/Infi-chu/ 1.框架架构图: 2.各文件功能scrapy.cfg 项目的配置文件items.py 定义了Item数据结构,所有 ...

  8. 爬虫 (5)- Scrapy 框架简介与入门

    Scrapy 框架 Scrapy是用纯Python实现一个为了爬取网站数据.提取结构性数据而编写的应用框架,用途非常广泛. 框架的力量,用户只需要定制开发几个模块就可以轻松的实现一个爬虫,用来抓取网页 ...

  9. 爬虫(十四):Scrapy框架(一) 初识Scrapy、第一个案例

    1. Scrapy框架 Scrapy功能非常强大,爬取效率高,相关扩展组件多,可配置和可扩展程度非常高,它几乎可以应对所有反爬网站,是目前Python中使用最广泛的爬虫框架. 1.1 Scrapy介绍 ...

随机推荐

  1. 柔弱的APP如何自我保护,浅谈APP防御手段,使用360加固助手加固/签名/多渠道打包/应用市场发布

    柔弱的APP如何自我保护,浅谈APP防御手段,使用360加固助手加固/签名/多渠道打包/应用市场发布 由于JAVA和Android的平台型,所以APP很容易被反编译,这对于我们开发者来说,是一个不想要 ...

  2. 2013暑假总结-SB学习

    经过暑假的学习,使英语原本基础不好的我找到了英语学习的感觉.方向.信心,暑假的这种团队学习英语的感觉才刚刚开始,即将开学了,我们并将保持着这学习的劲头坚持努力的做下去. 暑假35天英语的全职学习,对于 ...

  3. 程序员的软实力武器-smart原则

    smart对于程序员来说不是仅仅意味一个法则: 面对需求和提出需求时候,smart原则可以极大的提高效率 目标管理是使管理者的工作由被动变为主动的一个很好的管理手段,实施目标管理不仅是为了利于员工更加 ...

  4. Cocos2d中update与fixedUpdate的区别(五)

    在真实情况中update:和fixedUpdate方法如何去调用? 由上所述,所以update方法在每帧被调用1次,从而给你一个机会去更新你的游戏对象的状态在其绘制之前.而fixedUpdate:方法 ...

  5. Android实训案例(七)——四大组件之一Service初步了解,实现通话录音功能,抽调接口

    Service Service的神奇之处,在于他不需要界面,一切的操作都在后台操作,所以很多全局性(手机助手,语音助手)之类的应用很长需要这个,我们今天也来玩玩 我们新建一个工程--ServiceDe ...

  6. 从硬件竞争到软实力PK——电视媒体竞争观察

    本文观点及数据摘自中广研究<三网融合月度精粹>第26期(2013年2月版),详细参考对应在线简版(http://doc.sarft.net/index.php?f=2013/02/2013 ...

  7. 系统性能监测(使用nmon、nmonanalyser)

    系统性能监测使用工具: l系统性能监测使用的主要监测工具是:nmon(AIX6.1及以上版本系统自带). l系统性能监测使用的主要分析工具是:nmonanalyser. NMON工具简介: NMON工 ...

  8. iOS监听模式之KVO、KVC的高阶应用

    KVC, KVO作为一种魔法贯穿日常Cocoa开发,笔者原先是准备写一篇对其的全面总结,可网络上对其的表面介绍已经够多了,除去基本层面的使用,笔者跟大家谈下平常在网络上没有提及的KVC, KVO进阶知 ...

  9. jdk8中tomcat修改配置PermSize为MetaspaceSize

    JDK8中用metaspace代替permsize,因此在许多我们设置permsize大小的地方同样需要修改配置为metaspace 将-XX:PermSize=200m;-XX:MaxPermSiz ...

  10. android 实现倒影

    首先,文章中出现的Gallery 已经不再适用,替代方法请看我的另一篇文章http://blog.csdn.net/xiangzhihong8/article/details/51120460 不过对 ...