免费代理IP和爬虫代理的区别

10 篇文章 0 订阅
9 篇文章 0 订阅

作为一个资深的网络爬虫工作者,经常会在爬虫业务中,遇到各种疑难杂症。例如爬虫访问网站获取数据是IP受到限制等,一般遇到这种情况,我就会选择使用免费代理IP来进行数据采集。那如果获取免费代理IP呢?
免费代理IP的获取很简单,通过网站搜索关键词就能出现大量免费IP,我们可以通过爬虫程序去筛选可用的IP。一般免费代理IP适合那些业务小对IP数量小的爬虫用户。网上的免费代理IP种类有很多,其实对于许多爬虫用户来说,免费代理IP也是一种选择, 当然在使用免费代理IP的时候需要考虑IP的稳定性客户有效性。对于免费代理IP来说,稳定性和有效性刚好是它们的通用缺点,需要花费大量的时间精力来筛选可用IP资源。这样在爬虫业务中,大部分时间都花在了筛选有效的代理IP去了,而且浪费了业务的进展。如果网络爬虫是公司企业,需求量较大的,一般不推荐使用免费代理IP,毕竟网络上的免费代理IP质量,效率都比较低。建议可以使用更加高质量的自动隧道转发的爬虫代理加强版,这样对业务效果会好很多。
爬虫代理加强版:

        package main

        import (
            "net/url"
            "net/http"
            "bytes"
            "fmt"
            "io/ioutil"
        )

        // 代理服务器(产品官网 www.16yun.cn)
        const ProxyServer = "t.16yun.cn:31111"

        type ProxyAuth struct {
            Username string
            Password string
        }

        func (p ProxyAuth) ProxyClient() http.Client {

            var proxyURL *url.URL
            if p.Username != ""&& p.Password!="" {
                proxyURL, _ = url.Parse("http://" + p.Username + ":" + p.Password + "@" + ProxyServer)
            }else{
                proxyURL, _ = url.Parse("http://" + ProxyServer)
            }
            return http.Client{Transport: &http.Transport{Proxy:http.ProxyURL(proxyURL)}}
        }

        func main()  {


            targetURI := "https://httpbin.org/ip"


            // 初始化 proxy http client
            client := ProxyAuth{"username",  "password"}.ProxyClient()

            request, _ := http.NewRequest("GET", targetURI, bytes.NewBuffer([] byte(``)))

            // 设置Proxy-Tunnel
            // rand.Seed(time.Now().UnixNano())
            // tunnel := rand.Intn(10000)
            // request.Header.Set("Proxy-Tunnel", strconv.Itoa(tunnel) )

            response, err := client.Do(request)

            if err != nil {
                panic("failed to connect: " + err.Error())
            } else {
                bodyByte, err := ioutil.ReadAll(response.Body)
                if err != nil {
                    fmt.Println("读取 Body 时出错", err)
                    return
                }
                response.Body.Close()

                body := string(bodyByte)

                fmt.Println("Response Status:", response.Status)
                fmt.Println("Response Header:", response.Header)
                fmt.Println("Response Body:\n", body)
            }
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值