Python爬虫--伪装成浏览器

把爬虫伪装成浏览器

1. 技术原理

我们不讲很官方的属于,

简单的讲就是,一些论坛啊,博客啊

为防止别人爬他们的文章,

通常会判断是不是浏览器访问,如果不是那就屏蔽。


2. 实战

由于 urlopen() 对于一些HTTP的高级功能不支持,

所以,我们如果要修改报头,也就是添加 header

可以使用 urllib.request.build_opener() 进行,

当然,也可以使用 urllib.request.Request() 下的 add_header() 实现浏览器的模拟。

build_opener 的作用:

要爬取的各种各样的网页,它们有一部填写需要验证码,有的需要 cookie,还有更多许多高级的功能,

它们会阻碍你爬,而我对于openurl单纯地理解就是打开网页,

它可以是一个字符串或者是一个 request 对象。而 build_opener 就是多了 handler ,处理问题更专业,更个性化。

代码:

复制代码
import urllib.request

url = "http://blog.csdn.net"

headers = (

	"User-Agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.100 Safari/537.36"

	)

opener = urllib.request.build_opener()

opener.addheaders = [headers]  # 添加 headers 头

data = opener.open(url).read()

print(data)

urllib 有些方面还是没 request 好。

相关推荐
Loo国昌1 分钟前
【AI应用开发实战】07_文档解析路由与质量评估:从传统PDF解析到Docling现代化方案
人工智能·后端·python·自然语言处理·pdf
凌云拓界4 分钟前
TypeWell全攻略:AI健康教练+实时热力图开发实战 引言
前端·人工智能·后端·python·交互·pyqt·数据可视化
开开心心就好5 分钟前
文字转语音无字数限,对接微软接口比付费爽
java·linux·开发语言·人工智能·pdf·语音识别
xyq20248 分钟前
Perl 发送邮件:全面指南
开发语言
cui_ruicheng9 分钟前
C++ 继承(下):多继承、菱形继承与虚继承
开发语言·c++
派大星-?15 分钟前
自动化测试五模块一框架(上)
开发语言·python·测试工具·单元测试·可用性测试
草莓熊Lotso16 分钟前
Qt文件操作:QFile读写全解析
运维·开发语言·c++·人工智能·qt
S-码农17 分钟前
Linux——互斥锁
linux·开发语言
Drifter_yh20 分钟前
「JVM」 Java 类加载机制与双亲委派模型深度解析
java·开发语言·jvm
xyq202422 分钟前
《Ionic 卡片:设计理念与实战指南》
开发语言