当前位置: 首页 > news >正文

网络爬虫请求头中的Referer和User-Agent与代理IP的配合使用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8EJgMcgK-1691050515642)(https://cdn.nlark.com/yuque/0/2023/png/1313150/1691048724422-2a76d7b8-3ec3-48b7-9aec-d609d09b16d4.png#averageHue=%2385b0a7&clientId=u3856fd20-7701-4&from=ui&id=u75f920fe&originHeight=512&originWidth=512&originalType=binary&ratio=1&rotation=0&showTitle=false&size=481263&status=done&style=none&taskId=uafc1b696-d7fe-482b-bb71-207c932f8e1&title=)]
在进行网络爬虫开发时,我们经常需要模拟浏览器发送请求来获取网页数据。然而,有些网站为了保护自身的安全和隐私,会对请求进行限制和过滤。为了绕过这些限制,我们可以使用代理IP来隐藏真实的请求来源。但是,仅仅使用代理IP可能不足以达到我们的目的,因为一些网站会根据请求头中的Referer和User-Agent信息来判断请求的合法性。因此,本文将探讨网络爬虫请求头中的Referer和User-Agent与代理IP的配合使用的技巧和注意事项。

  1. Referer的作用: Referer是HTTP请求头中的一个字段,用于指示请求的来源页面。一些网站会根据Referer来判断请求的合法性,如果Referer为空或者不符合预期的值,可能会拒绝请求或返回错误的数据。
  2. User-Agent的作用: User-Agent也是HTTP请求头中的一个字段,用于标识发送请求的客户端信息,通常是浏览器的名称和版本号。

常见格式: User-Agent的格式通常为"产品名称/产品版本号",例如:

  • Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.182 Safari/537.36
  • Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.192 Safari/537.36

在实际开发中,我们可能会遇到一些问题,例如请求被拒绝、返回错误的数据等。这些问题可能与请求头中的Referer和User-Agent有关。为了解决这些问题,我们可以按照以下步骤进行问题排查:

  1. 检查请求头中的Referer和User-Agent是否正确设置:使用浏览器访问目标网站,查看浏览器的请求头信息,确保Referer和User-Agent与浏览器请求一致。
import requestsheaders = {'Referer': 'https://www.example.com'
}response = requests.get('https://www.target-website.com', headers=headers)
  1. 检查代理IP是否正常工作:使用代理IP发送请求,查看返回的数据是否正确。如果返回的数据与预期不符,可能是代理IP被网站识别并拒绝了请求。
import requests# 通过亿牛云爬虫代理来测试
proxyHost = 't.16yun.cn'
proxyPort = 30001# 设置请求头
headers = {'Referer': 'https://www.example.com','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.182 Safari/537.36'
}# 设置代理
proxies = {'http': f'http://{proxyHost}:{proxyPort}','https': f'https://{proxyHost}:{proxyPort}'
}# 发送请求
response = requests.get('https://www.example.com', headers=headers, proxies=proxies)# 处理响应
print(response.text)
  1. 检查Referer和User-Agent的值是否被网站限制:有些网站会对Referer和User-Agent的值进行限制,例如只接受特定的Referer或User-Agent。如果您的请求被拒绝或返回错误的数据,因为可能是您设置的Referer或User-代理不符合网站要求。
import requests# 设置请求头
headers = {'Referer': 'https://www.example.com','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.182'
}# 发送请求
response = requests.get('https://www.target-website.com', headers=headers)# 处理响应
print(response.text)
http://www.lryc.cn/news/110906.html

相关文章:

  • RabbitMQ 生产者-消息丢失 之 场景分析
  • Hyper实现git bash在windows环境下多tab窗口显示
  • Matlab的信号频谱分析——FFT变换
  • 如何从 Android 设备恢复已删除的文件?
  • servlet生命周期和初始化参数传递
  • dvwa靶场通关(十一)
  • 【Spring】使用注解存储Bean对象
  • 怎么维护好自己的电脑
  • vscode中无法使用git解决方案
  • MybatisPlus-CRUD,不带条件构造器的常用方法
  • 软件测试面试【富途面经分享】
  • antd 库的 Table 组件中删除一个或多个选中的列表
  • 针对java程序员的了解细节操作系统与进程
  • 判定是否互为字符重排、回文排列
  • QT QTextCharFormat 说明和使用
  • 掌握Memory Profiler技巧:识别内存问题
  • Linux学习之正则表达式元字符和grep命令
  • 熟练掌握ChatGPT解决复杂问题——学会提问
  • JVM之类加载与字节码
  • 【博客688】如何实现keepalived vip监控与告警
  • [QT编程系列-39]:用户界面UI - 样式表QSS与样式文件快速入门
  • 机器学习和深度学习简述
  • diffusion model2 扩散模型的文本信息融合、交叉注意力机制、lora
  • 数据结构——二叉树
  • 架构训练营学习笔记:5-3接口高可用
  • 【笔记】湖仓一体架构演进与发展
  • 政务云建设与应用解决方案[42页PPT]
  • 20天突破英语四级高频词汇——第①天
  • 【网络基础实战之路】基于MGRE多点协议的实战详解
  • K8s实战入门(三)