首页 > 其他 > 详细

scrapy设置代理

时间:2017-01-21 16:02:41      阅读:307      评论:0      收藏:0      [点我收藏+]

在爬取网站内容的时候,最常遇到的问题是:网站对IP有限制,会有防抓取功能,最好的办法就是IP轮换抓取(加代理)

下面来说一下Scrapy如何配置代理,进行抓取

1.在Scrapy工程下新建“middlewares.py”

# Importing base64 library because we‘ll need it ONLY in case if the proxy we are going to use requires authentication
import base64
# Start your middleware class
class ProxyMiddleware(object):
    # overwrite process request
   
def process_request(self, request, spider):
        # Set the location of the proxy
       
request.meta[‘proxy‘] = "http://proxyhk.huawei.com:8080"
 
       
# Use the following lines if your proxy requires authentication
       
proxy_user_pass = "username:password"
       
# setup basic authentication for the proxy
       
encoded_user_pass = base64.encodestring(proxy_user_pass)
        request.headers[‘Proxy-Authorization‘] = ‘Basic ‘ + encoded_user_pass

 

2.在项目配置文件里(./pythontab/settings.py)添加

 

DOWNLOADER_MIDDLEWARES = {
## ‘scrapy.contrib.downloadermiddleware.httpproxy.HttpProxyMiddleware‘: None,
‘scrapy.downloadermiddlewares.httpproxy.HttpProxyMiddleware‘: None,
‘wikiSpider.middlewares.ProxyMiddleware‘: 543
}

 

scrapy设置代理

原文:http://www.cnblogs.com/BigFishFly/p/6337137.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!