一、前言

随着互联网的不断发展,越来越多的应用需要使用高匿代理IP才能访问目标网站,而代理IP作为一种能够隐藏本机真实IP地址的工具,在网络抓取、搜索引擎排名、广告投放、反爬虫等方面有着广泛的应用场景。但是,由于代理IP的稳定性难以保证,而且容易被反爬虫机制识别和封杀,为解决这些问题,我们可以通过构建一个代理IP池来实现代理IP的有效管理和使用。

本文将介绍如何使用Python语言和开源爬虫框架Scrapy,构建一个高匿代理IP池,并提供完整的代码和案例。

二、代理IP池的构建流程

构建代理IP池的大致流程如下:

1.爬取代理IP数据
2.验证代理IP的有效性和匿名性
3.将有效的代理IP保存到代理IP池中
4.从代理IP池中随机获取一个代理IP并使用

接下来,我们将详细介绍每个步骤的实现方式。

2.1、爬取代理IP数据

在构建代理IP池之前,我们需要先收集一些代理IP数据。这里我们可以使用一些代理IP网站上的API接口或者直接爬取网站上的代理IP数据。

以爬取站大爷代理网站为例,其网站上提供了一个可以直接访问的代理IP列表页面,我们可以从该页面中提取出代理IP地址和端口号等信息。

以下为爬取站大爷代理网站的代理IP数据的代码实现:

import scrapy

class XiciSpider(scrapy.Spider):
    name = 'xici'
    allowed_domains = ['www.zdaye.com']
    start_urls = ['http://www.zdaye.com/']

def parse(self, response):
        item_list = response.xpath('//table[@id="ip_list"]//tr')[1:]
        for item in item_list:
            ip = item.xpath('.//td[2]/text()').get()
            port = item.xpath('.//td[3]/text()').get()
            yield {
                'ip': ip,
                'port': port
            }

以上代码中,我们使用Scrapy框架爬取西刺代理网站,爬取其网页上的代理IP地址和端口号,并以字典的格式保存到内存中。

2.2、验证代理IP的有效性和匿名性

由于代理IP的可用性和匿名性是不稳定的,我们需要定期验证其有效性和匿名性。验证代理IP可用性的方法是通过访问目标网站并获取目标网页的数据,如果获取到了数据,则说明该代理IP可用;否则,则说明该代理IP不可用。

验证代理IP匿名性的方法是通过访问代理IP网站上的检测页面,检测代理IP是否真正地隐藏了客户端的真实IP地址。我们可以使用Python的requests库发起HTTP请求和获取HTTP响应,判断目标网站的状态码和返回的内容是否符合要求。

以下为验证代理IP有效性和匿名性的代码实现:

import requests

def validate_proxy(proxy):
    url = 'http://httpbin.org/get'
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    try:
        response = requests.get(url, proxies=proxies, timeout=10)
        if response.status_code == 200 and response.json().get('origin'):
            return True
    except:
        pass
    return False

def check_anonymous(proxy):
    url = 'https://www.baidu.com/'
    headers = {
        'User-Agent': 'Mozilla/5.0'
    }
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    try:
        response = requests.get(url, headers=headers, proxies=proxies, timeout=10)
        if response.status_code == 200 and 'baidu' in response.text:
            return True
    except:
        pass
    return False

以上代码中,我们定义了两个函数validate_proxy和check_anonymous,用于验证代理IP的有效性和匿名性。其中,validate_proxy函数会访问httpbin.org网站,并从响应数据中获取客户端的ip地址,如果获取到了数据,则说明该代理IP可用;否则,则说明不可用。check_anonymous函数会访问百度首页,并判断访问结果是否为正常页面,如果是,则说明代理IP匿名性高;否则,则说明代理IP匿名性低。

2.3、将有效的代理IP保存到代理IP池中

当我们验证出一批有效的代理IP时,可以将其保存到代理IP池中,以便于后续使用。

以下为将代理IP保存到代理IP池中的代码实现:

import redis

class ProxyPool(object):

def __init__(self):
        self.client = redis.Redis(host='localhost', port=6379, db=0, password='')

def add(self, proxy):
        self.client.sadd('proxy_pool', str(proxy))

def remove(self, proxy):
        self.client.srem('proxy_pool', str(proxy))

def random(self):
        return eval(self.client.srandmember('proxy_pool'))

def all(self):
        return [eval(p) for p in self.client.smembers('proxy_pool')]

以上代码中,我们使用Redis数据库作为代理IP池的存储工具,通过在Redis中创建一个set类型的key值proxy_pool,来存储所有可用的代理IP。在这里,我们定义了一个名为ProxyPool的类,用于对代理IP池进行增删改查的操作。

2.4、从代理IP池中随机获取一个代理IP并使用

当我们需要使用代理IP访问目标网站时,可以从代理IP池中随机获取一个代理IP,并将其添加到requests库的代理参数proxies中,以便于使用代理IP来访问目标网站。

以下为从代理IP池中随机获取一个代理IP的代码实现:

def get_random_proxy():
    proxy_pool = ProxyPool()
    proxy = proxy_pool.random()
    while not validate_proxy(proxy):
        proxy_pool.remove(proxy)
        proxy = proxy_pool.random()
    return proxy

def download(url):
    proxy = get_random_proxy()
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    headers = {
        'User-Agent': 'Mozilla/5.0'
    }
    try:
        response = requests.get(url, headers=headers, proxies=proxies, timeout=10)
        if response.status_code == 200:
            return response.text
    except:
        pass
    return None

以上代码中,我们使用get_random_proxy随机获取一个代理IP,并使用validate_proxy函数验证该代理IP是否可用,如果该代理IP不可用,则从代理IP池中删除该代理IP,并重新获取。当获取到可用的代理IP后,我们将其添加到requests库的参数proxies中,并使用requests库来访问目标网站。

三、完整代码实现

将以上代码整合到一个文件中,得到完整的高匿代理IP池的实现方式,代码如下:

import scrapy
import requests
import redis

class XiciSpider(scrapy.Spider):
    name = 'xici'
    allowed_domains = ['www.xicidaili.com']
    start_urls = ['http://www.xicidaili.com/']

def parse(self, response):
        item_list = response.xpath('//table[@id="ip_list"]//tr')[1:]
        for item in item_list:
            ip = item.xpath('.//td[2]/text()').get()
            port = item.xpath('.//td[3]/text()').get()
            proxy = {
                'ip': ip,
                'port': port
            }
            if validate_proxy(proxy) and check_anonymous(proxy):
                add_proxy(proxy)

def validate_proxy(proxy):
    url = 'http://httpbin.org/get'
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    try:
        response = requests.get(url, proxies=proxies, timeout=10)
        if response.status_code == 200 and response.json().get('origin'):
            return True
    except:
        pass
    return False

def check_anonymous(proxy):
    url = 'https://www.baidu.com/'
    headers = {
        'User-Agent': 'Mozilla/5.0'
    }
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    try:
        response = requests.get(url, headers=headers, proxies=proxies, timeout=10)
        if response.status_code == 200 and 'baidu' in response.text:
            return True
    except:
        pass
    return False

class ProxyPool(object):

def __init__(self):
        self.client = redis.Redis(host='localhost', port=6379, db=0, password='')

def add(self, proxy):
        self.client.sadd('proxy_pool', str(proxy))

def remove(self, proxy):
        self.client.srem('proxy_pool', str(proxy))

def random(self):
        return eval(self.client.srandmember('proxy_pool'))

def all(self):
        return [eval(p) for p in self.client.smembers('proxy_pool')]

def add_proxy(proxy):
    proxy_pool = ProxyPool()
    proxy_pool.add(proxy)

def get_random_proxy():
    proxy_pool = ProxyPool()
    proxy = proxy_pool.random()
    while not validate_proxy(proxy):
        proxy_pool.remove(proxy)
        proxy = proxy_pool.random()
    return proxy

def download(url):
    proxy = get_random_proxy()
    proxies = {
        'http': 'http://{ip}:{port}'.format(**proxy),
        'https': 'https://{ip}:{port}'.format(**proxy)
    }
    headers = {
        'User-Agent': 'Mozilla/5.0'
    }
    try:
        response = requests.get(url, headers=headers, proxies=proxies, timeout=10)
        if response.status_code == 200:
            return response.text
    except:
        pass
    return None

if __name__ == '__main__':
    from multiprocessing import Process

spider_process = Process(target=scrapy.cmdline.execute, args=('scrapy crawl xici',))
    spider_process.start()

while True:
        url = input('请输入需要访问的URL:')
        print(download(url))

spider_process.join()

在代码中,我们首先定义了XiciSpider类,用于爬取西刺代理网站上的代理IP数据。然后,我们使用requests库对代理IP进行验证,并使用Redis来保存可用的代理IP。最后,我们定义了get_random_proxy函数,从代理IP池中随机获取一个代理IP,并使用requests库来访问目标网站。

总结

Python开源代理IP池是一个非常有用的工具,它可以帮助我们自动爬取和验证代理IP,并将可用的代理IP保存到一个池中,供我们在爬虫或其他需要访问目标网站时使用,可以有效地避免IP被封杀的问题。

【python】python开源代理ip池的更多相关文章

  1. python爬虫构建代理ip池抓取数据库的示例代码

    爬虫的小伙伴,肯定经常遇到ip被封的情况,而现在网络上的代理ip免费的已经很难找了,那么现在就用python的requests库从爬取代理ip,创建一个ip代理池,以备使用. 本代码包括ip的爬取,检 ...

  2. python多线程建立代理ip池

    之前有写过用单线程建立代理ip池,但是大家很快就会发现,用单线程来一个个测试代理ip实在是太慢了,跑一次要很久才能结束,完全无法忍受.所以这篇文章就是换用多线程来建立ip池,会比用单线程快很多.之所以 ...

  3. Python爬虫代理IP池

    目录[-] 1.问题 2.代理池设计 3.代码模块 4.安装 5.使用 6.最后 在公司做分布式深网爬虫,搭建了一套稳定的代理池服务,为上千个爬虫提供有效的代理,保证各个爬虫拿到的都是对应网站有效的代 ...

  4. Python 爬虫的代理 IP 设置方法汇总

    本文转载自:Python 爬虫的代理 IP 设置方法汇总 https://www.makcyun.top/web_scraping_withpython15.html 需要学习的地方:如何在爬虫中使用 ...

  5. 利用代理IP池(proxy pool)搭建免费ip代理和api

    先看这里!!!---->转载:Python爬虫代理IP池(proxy pool) WIIN10安装中遇到的问题: 一.先安装Microsoft Visual C++ Compiler for P ...

  6. 自建免费的代理ip池

    00x01--- 前言 因为爬虫被禁ip这样的反扒真的很凶,但自从建了一个代理ip池以后,反反扒就可以跟的上节奏.当然你也可以上网上各种代理平台自己付费.这些平台当然很方便提供api调用,还不用自己验 ...

  7. 【python3】如何建立爬虫代理ip池

    一.为什么需要建立爬虫代理ip池 在众多的网站防爬措施中,有一种是根据ip的访问频率进行限制的,在某段时间内,当某个ip的访问量达到一定的阀值时,该ip会被拉黑.在一段时间内被禁止访问. 这种时候,可 ...

  8. 建立爬虫代理IP池

    单线程构建爬虫代理IP池 #!/usr/bin/python3.5 # -*- coding:utf-8 -*- import time import tempfile from lxml impor ...

  9. 做了一个动态代理IP池项目,邀请大家免费测试~

    现在出来创业了,目前公司在深圳. 做了啥呢, 做了一个动态代理 IP 池项目 现在邀请大家免费测试体验! 免费激活码:关注微信公众号:2808proxy (每人每天限领一次噢~) 网站:https:/ ...

  10. springboot实现java代理IP池 Proxy Pool,提供可用率达到95%以上的代理IP

    一.背景 前段时间,写java爬虫来爬网易云音乐的评论.不料,爬了一段时间后ip被封禁了.由此,想到了使用ip代理,但是找了很多的ip代理网站,很少有可以用的代理ip.于是,抱着边学习的心态,自己开发 ...

随机推荐

  1. JupyterLab Server 搭建与使用笔记

    两三个月前,有幸拿到了云筏的一个 4 核 16G,1TB硬盘,300M带宽位于欧洲的云服务器,自带的开箱即用的 RStudio Server 也非常给力,但最近这两天在升级 R 的时候遇上了不少问题, ...

  2. 聊一聊 Rust 的 stack overflow

    早上看到了这篇文章 智能指针有可能会让你的应用崩溃, 下面分析一下 会导致 stack overflow 的代码 struct Node<T> { val: T, next: Option ...

  3. Linux系统运维之FastDFS集群部署

    一.简介 FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的问题.FastDFS服务端有两个 ...

  4. 最简单的人脸检测(免费调用百度AI开放平台接口)

    远程调用百度AI开放平台的web服务,快速完成人脸识别 欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos ...

  5. JS逆向实战20——某头条jsvm逆向

    声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 网站 目标网站:aHR0c ...

  6. 即构发布 LCEP 低代码互动平台产品 RoomKit,实现互动房间0代码搭建

    2月5日,全球云通讯服务商ZEGO即构科技发布低代码互动平台 LCEP(Low-code Engagement Platform)产品 RoomKit,支持1V1在线课堂.小班课.大班课.视频会议.视 ...

  7. 即构微信小程序直播组件是什么?有哪些功能?哪些小程序类目可以使用?

    即构直播助手是微信官方认证的微信小程序插件,为开发者提供便捷.强大的微信小程序音视频直播服务. 即构直播助手除了包含微信小程序下的音视频推拉流能力,还支持iOS.Android.Windows.Web ...

  8. CMU15-445 Project3 Query Execution心得

    Project3 Query Execution 心得 一.概述 首先要说:这个 project很有趣很硬核!从这个 project 开始才感觉自己在数据库方面真正成长了! 第一个 project : ...

  9. Python日志模块:实战应用与最佳实践

    本文详细解析了Python的logging模块,从基本介绍到实际应用和最佳实践.我们通过具体的代码示例解释了如何高效地使用这个模块进行日志记录,以及如何避免常见的陷阱,旨在帮助读者更好地掌握这个强大的 ...

  10. React:TypeError: Cannot read properties of undefined (reading 'map')

    解决方案 js中?问号代表可选项 可选链式操作符 参考链接 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Oper ...