"); //-->
网络爬虫,是一种自动获取网页内容的程序,是搜索引擎的重要组成部分。一般人能访问到的网页,爬虫也都能抓取。爬虫抓取,就是模拟真实用户浏览网页采集数据。爬虫是可以按照一定的规则,自动的采集信息。
正常的用户访问网站浏览时间较长,访问也不会太过于频繁,目标网站服务器会限制爬虫行为,这是就需要降低访问评率或者停止访问或者用http代理去配合爬虫访问
HTTP代理分很多类型,至于选择哪种类型的代理IP最适合爬虫,看个人业务的需求,需求大的业务,对IP池要求大的可以选择一些高质量的隧道转发的爬虫代理加强版。
HTTP代理的作用:1、通过HTTP代理访问一些被反爬的网站。
2、加快访问目标网站的速度。
3、修改本地外网,隐藏本地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)
}
}专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
图形总线大战:ISA、AGP和PCI的延展
pocket pc中开发自己的service
555FM无线发射电路
村田发布首款搭载XBAR技术的商品化高频滤波器
555多功能遥控电路
CES 2010:Lenovo S10-3t 小平板
AI摄像头改变驾驶员在十字路口的行为
CES 2010:联想LePhone
555遥控式多档控制器电路
12位DorA转换器AD7564
[求助]求Vxwork/ tornado II 常见问题解答 中文版,急!!!
6G的采用将首先是一个拼凑的过程
pppd&chat程序总是出错
555多用途比例控制器电路
本人初学者,诚心请教各位EP7312的问题!
研华AIR-120紧凑型边缘AI系统上市:助力AI应用加快落地进程
0-30Vor2A电源的制作
200W ATX PC 电源电原理图
三菱FX系列PLC教程 79 —— FX系列的模拟量开关设定指令
12位并行模数转换芯片AD1674及其应用
消费科技品牌Nothing采用Ceva的RealSpace软件为耳机和耳塞用户带来身临其境的空间音频体验
优必选成立智行机器人公司,注册资本5000万元
16C5X模拟串口
AI将高端移动设备从 SoC 推向多晶粒
有酬求助,一个关于S3C44B0X的USB通信编程问题
CES 2010:联想Lenovo IdeaPad U1 Hybrid
555电力载波遥控开关电路
三菱FX系列PLC教程 80 —— FX系列的模拟量输入指令
Nordic Semiconductor推出高度集nPM1304电源管理IC支持小尺寸电池产品
翼菲科技冲刺港股, 堪称轻工业机器人先锋