位置: IT常识 - 正文

有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊(常见反爬策略)

编辑:rootadmin
有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊 文章目录一、从用户请求的Headers反爬虫二、基于用户行为反爬虫(1)方法1(2)方法2三、动态页面的反爬虫四.总结

推荐整理分享有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊(常见反爬策略),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:爬虫的反爬机制是不允许被破解的,常见反爬策略,反反爬技术,反爬机制有哪些,反爬怎么办,反爬怎么办,常见反爬策略,反爬机制有哪些,内容如对您有帮助,希望把文章链接给更多的朋友!

不知道你们在用爬虫爬数据的时候是否有发现,越来越多的网站都有自己的反爬机制,抓取数据已经不像以前那么容易,目前常见的反爬机制主要有以下几种:

数据是通过动态加载的,比如微博,今日头条,b站需要登录,需要验证码,比如铁路12306,淘宝,京东请求次数频繁,IP地址在同一时间访问次数过多,导致IP被封数据屏蔽方式,比如访问的数据不在源码中,数据隐藏在js中,比如今日分享,b站

爬虫与反爬虫一直以来就像是左右手互博,你有反爬机制,我就有反反爬技术,即见即可爬,道高一尺魔高一丈。

今天就为大家详细介绍网站的反爬虫机制和实用的应对方法,一般网站从三个方面反爬虫:

1.用户请求的Headers 2.用户行为 3.网站目录和数据加载方式

前两种比较容易遇到,大多数网站都从这些角度来反爬虫。第三种一些应用ajax的网站会采用,这样增大了爬取的难度(防止静态爬虫使用ajax技术动态加载页面)。

一、从用户请求的Headers反爬虫

这种是最常见的反爬机制,在访问某些网站的时候,网站通常会用判断访问是否带有头文件来鉴别该访问是否为爬虫,用来作为反爬取的一种策略。

那我们就需要伪装headers。很多网站都会对Headers的User-Agent进行检测,还有一部分网站会对Referer进行检测(一些资源网站的防盗链就是检测Referer)。

如果遇到了这类反爬虫机制,可以直接在爬虫中添加Headers,将浏览器的User-Agent复制到爬虫的Headers中;或者将Referer值修改为目标网站域名。

往往容易被忽略,通过对请求的抓包分析,确定referer,在程序中模拟访问请求头中添加。

对于检测Headers的反爬虫,在爬虫中修改或者添加Headers就能很好的绕过。

例如打开搜狐首页,先来看一下Chrome的头信息(F12打开开发者模式)如下:

如图,访问头信息中显示了浏览器以及系统的信息(headers所含信息众多,其中User-Agent就是用户浏览器身份的一种标识,具体可自行查询)

Python中urllib中的request模块提供了模拟浏览器访问的功能,代码如下:

from urllib import requesturl = http://www. baidu.com # page= requestRequest (url)# page add header (' User-Agent',' Mozilla/5.0(Windows NT 10.0; Win64; x64) AppleWebkiheaders ={'User-Agent': ' Mozilla/5.0(Windows NT 10.0; Win64; x64) AppleWebkit/537. 36'}page = request Request(url, headersheaders)page_info = request urlopen(page). read().decode('utf-8')print(page_info)

可以通过add_header(key, value) 或者直接以参数的形式和URL一起请求访问

urllib.request Request()urllib.request Request(url, data=None, headers={}, origin req host=None, unverifiable )

其中headers是一个字典,通过这种方式可以将爬虫模拟成浏览器对网站进行访问。

二、基于用户行为反爬虫

还有一部分网站是通过检测用户行为,例如同一IP短时间内多次访问同一页面,或者同一账户短时间内多次进行相同操作。

有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊(常见反爬策略)

这种防爬,需要有足够多的ip来应对。

(1)方法1

大多数网站都是前一种情况,对于这种情况,使用IP代理就可以解决。可以专门写一个爬虫,爬取网上公开的代理ip,检测后全部保存起来。有了大量代理ip后可以每请求几次更换一个ip,这在requests或者urllib中很容易做到,这样就能很容易的绕过第一种反爬虫。

编写爬虫代理:

步骤:

1.参数是一个字典{‘类型’:‘代理ip:端口号’}   proxy_support=urllib.request.ProxyHandler({}) 2.定制、创建一个opener   opener=urllib.request.build_opener(proxy_support) 3.安装opener   urllib.request.install_opener(opener) 4.调用opener   opener.open(url)

用大量代理随机请求目标网站,应对反爬虫

import urllib requestimport random import reurl='http://www. whatismyip. com. tw 'iplist=['121.193.143.249:88',"112.126.65.193:88',122.96.59.184:82',115.29.98.139:9]proxy_support = urllib. request Proxyhandler({'httP': random choice(iplist)})opener = urllib.request.build_opener(proxy_suppor)opener.addheaders=[(' User-Agent, ' Mozilla/5.0(X11; Linux x86-64) AppleWebkit/537.36'urllib.request.install_opener(opener)response = urllib.request.urlopen(url)html = response.read().decode(' utf-8)pattern = re.compile('<h1>(.*?)</h1>.*?<h2>(,*?)</h2>')iterms=re.findall(pattern, html)for item in iterms: print(item[0]+:"+item[1])(2)方法2

对于第二种情况,可以在每次请求后随机间隔几秒再进行下一次请求。有些有逻辑漏洞的网站,可以通过请求几次,退出登录,重新登录,继续请求来绕过同一账号短时间内不能多次进行相同请求的限制。

对于账户做防爬限制,一般难以应对,随机几秒请求也往往可能被封,如果能有多个账户,切换使用,效果更佳。

三、动态页面的反爬虫

上述的几种情况大多都是出现在静态页面,还有一部分网站,我们需要爬取的数据是通过ajax请求得到,或者通过Java生成的。

解决方案:Selenium+PhantomJS

Selenium:自动化web测试解决方案,完全模拟真实的浏览器环境,完全模拟基本上所有的用户操作

PhantomJS :一个没有图形界面的浏览器

比如获取淘宝的个人详情地址:

from selenium import webdriverimport time import re drive = webdriver.PhantomJs(executable_path = ' phantomjs-21.1-linux-x86 64/bin/phanto drive.get('https://mm. taobaocom/self/modelinfohtm? userid=189942305& iscoment=fal)time. sleep(5)pattern = re.compile(r'<div. *? mm-p-domain-info>*? class="mm-p-info-cell clearfix">.html = drive.page_source.encode(' utf-8,' ignore')items=re.findall(pattern, html)for item in items:print(item[0], 'http':+item[1])drive.close()

四.总结

最后给大家总结一下前面所讲的反爬机制应对策略(反反爬):

伪装浏览器

使用代理IP

抓包分析突破异步加载 / selenium自动化测试工具

添加cookie

最后嘱咐大家一句,爬虫世界确实很有意思,技术是无罪的,学习是可以的,但还是实际操作就要适可而止了,不要触碰到法律的边界线。

感谢你们的阅读和喜欢,我收藏了很多技术干货,可以共享给喜欢我文章的朋友们,如果你肯花时间沉下心去学习,它们一定能帮到你,干货内容包括:

点击文末的名片可以抱走

本文链接地址:https://www.jiuchutong.com/zhishi/298974.html 转载请保留说明!

上一篇:Web前端 | HTML嵌入JS代码的三种方式(嵌入html)

下一篇:五、IDEA中创建Web项目(idea2020.2.3创建web)

  • oppo手机管家怎么卸载(oppo手机管家怎么解除管控)

    oppo手机管家怎么卸载(oppo手机管家怎么解除管控)

  • 小米手机如何录屏幕视频(小米手机如何录屏视频教程)

    小米手机如何录屏幕视频(小米手机如何录屏视频教程)

  • 苹果xr死机(苹果XR死机是什么原因)

    苹果xr死机(苹果XR死机是什么原因)

  • 11的屏幕多大(苹果13的屏幕尺寸多大)

    11的屏幕多大(苹果13的屏幕尺寸多大)

  • 苹果手表和手机微信不同步(苹果手表和手机连接不上怎么办)

    苹果手表和手机微信不同步(苹果手表和手机连接不上怎么办)

  • 路由器闪蓝光怎么回事(路由器闪蓝光怎么解决)

    路由器闪蓝光怎么回事(路由器闪蓝光怎么解决)

  • 苹果5电池多少毫安(苹果5电池多少钱一个)

    苹果5电池多少毫安(苹果5电池多少钱一个)

  • 京东卡可以买哪些东西(京东卡买哪种划算)

    京东卡可以买哪些东西(京东卡买哪种划算)

  • 手机屏幕tp是什么意思

    手机屏幕tp是什么意思

  • 魅族17支持光学防抖吗(魅族17pro带光学防抖吗)

    魅族17支持光学防抖吗(魅族17pro带光学防抖吗)

  • 手机的充电口芯片歪了(手机的充电口芯片叫什么)

    手机的充电口芯片歪了(手机的充电口芯片叫什么)

  • 小爱同学无法语音唤醒(小爱同学无法语音唤醒如何解决?)

    小爱同学无法语音唤醒(小爱同学无法语音唤醒如何解决?)

  • 华为p40pro多大屏(华为mate40pro屏幕多少钱)

    华为p40pro多大屏(华为mate40pro屏幕多少钱)

  • 华硕笔记本充不进去电怎么回事(华硕笔记本充不满电是什么问题)

    华硕笔记本充不进去电怎么回事(华硕笔记本充不满电是什么问题)

  • 华为nove6se什么时候出(华为nova6se系列)

    华为nove6se什么时候出(华为nova6se系列)

  • 荣耀20青春版屏占比是多少(荣耀20青春版屏幕指纹坏了)

    荣耀20青春版屏占比是多少(荣耀20青春版屏幕指纹坏了)

  • wifi连接上不能上网怎么办(wifi连接上不能上网怎么办感叹号)

    wifi连接上不能上网怎么办(wifi连接上不能上网怎么办感叹号)

  • 拼多多怎么送免拼单卡(拼多多怎么送免单卡)

    拼多多怎么送免拼单卡(拼多多怎么送免单卡)

  • 拼多多修改绑定手机号(拼多多修改绑定手机号码)

    拼多多修改绑定手机号(拼多多修改绑定手机号码)

  • 参考文献怎么加入word(参考文献怎么加编号)

    参考文献怎么加入word(参考文献怎么加编号)

  • 5g来了现在换手机亏吗(5g出来要换卡还是换手机)

    5g来了现在换手机亏吗(5g出来要换卡还是换手机)

  • vivoy97怎样开启闪充(vivo手机y97怎么使用)

    vivoy97怎样开启闪充(vivo手机y97怎么使用)

  • 微信如何看与我相关(微信如何看与我的共同群)

    微信如何看与我相关(微信如何看与我的共同群)

  • 手机云端在哪里(手机云端在哪里能找到vivo)

    手机云端在哪里(手机云端在哪里能找到vivo)

  • Win11资源管理器未响应怎么办?Win11资源管理器无响应的解决办法(win11资源管理器卡死)

    Win11资源管理器未响应怎么办?Win11资源管理器无响应的解决办法(win11资源管理器卡死)

  • vue 中从后端获取到文件的 url 地址,前端根据 url 地址下载文件(vue怎么拿到后端数据)

    vue 中从后端获取到文件的 url 地址,前端根据 url 地址下载文件(vue怎么拿到后端数据)

  • 一年一度的施瓦本哈尔圣诞市集,德国巴登-符腾堡州 (© sack/Getty Images Plus)

    一年一度的施瓦本哈尔圣诞市集,德国巴登-符腾堡州 (© sack/Getty Images Plus)

  • 实收资本印花税最新规定
  • 工程结算时如何确认收入
  • 生产企业的基础设施是指
  • 反结账只能反结上月的账吗
  • 市场营销策划开题报告
  • 代账公司需要做报表吗
  • 房产交房前开发商要办齐的手续
  • 支付增值税税控系统技术维护费用500元
  • 股票印花税最新政策2023怎么算
  • 公司账户资金
  • 费用没有发票是什么意思
  • 会务费发票税点是多少
  • 员工社保异地缴纳
  • 发票添加商品编码怎么填
  • 怎么查询财务章备案信息
  • 增值税暂行条例属于
  • 增值税及附加税费减免一览表
  • 个人出租房屋税款代征点电话
  • 进口货物账务处理外币
  • 转结本月工资
  • 企业存款利息收入要交哪些税
  • 社保退休金计算方法
  • 工会经费是职工工资总额的
  • 游泳耳朵进水怎么办
  • 支付手续费委托代销是什么意思
  • 会计结账时账户余额为零
  • 支付工资属于费用吗
  • 浏览器分析
  • 提租补贴计入个税吗
  • 出租车发票能不能多开
  • VUE3.2 + vue-echarts + DataV 数据可视化大屏(项目)
  • 公司发给员工的股票
  • 出口收汇手续费做什么科目
  • 年底本年利润需要结转吗
  • 资产减值损失冲减
  • 税票抵扣是多少个点
  • 差额征税扣除额的具体规定
  • 税务异常怎么处理要多长时间
  • 固定资产投资子公司
  • 医疗服务增值税税率
  • 固定资产折旧加计扣除最新政策
  • 哪些情况发票可以红冲
  • 预付房租摊销从哪月算起
  • 收据能否入账
  • 一般纳税人购入固定资产进项抵扣
  • 消费税的计税方式有哪几种?
  • 计提增值税如何计算
  • 只有发票没有银行回单怎么做账
  • 未摊销的费用怎样处理
  • 已经入库的商品出库了要怎么做会计分录
  • 文化事业建设费税收优惠政策2022
  • 增值税进项税额在借方还是贷方
  • 营业外支出处置固定资产损失是坏账
  • sql server2005一个表中可以设置
  • Linux/UNIX和Window平台上安装Mysql
  • sql server的介绍
  • WINDOWS操作系统内置的GUEST
  • xp蓝屏事件
  • qcwlicon.exe - qcwlicon是什么进程 有何作用
  • sf2是什么文件
  • win7系统误删文件可以恢复吗
  • Linux系统配置IP地址
  • win7怎么安装网络驱动程序
  • Win10系统怎么截图快捷键
  • js实现dialog
  • 人工智能最受欢迎的一门编程语言
  • cocos2d怎么用
  • js 单引号
  • u盘备份系统操作步骤
  • jquery操作html代码
  • node.js的理解
  • javascript中的函数该如何理解
  • 美国税务制度
  • 地税局 业务
  • 如何在电子税务局申报社保
  • 贵阳税务官网登录
  • 如何开具红字发票明细
  • 车辆购置税税率多少
  • 设区市是哪里
  • 电子发票查询官方
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设