新闻  |   论坛  |   博客  |   在线研讨会
免费代理IP和爬虫代理的区别
laical | 2020-10-14 17:47:57    阅读:134   发布文章

作为一个资深的网络爬虫工作者,经常会在爬虫业务中,遇到各种疑难杂症。例如爬虫访问网站获取数据是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)
            }
        }


*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。

参与讨论
登录后参与讨论
推荐文章
最近访客