一些常见的反爬手段及解决思路

常见的反爬手段和解决思路

反反爬的主要思路

反反爬的主要思路就是:尽可能的去模拟浏览器,浏览器在如何操作,代码中就如何去实现。浏览器先请求了地址url1,保留了cookie在本地,之后请求地址url2,带上了之前的cookie,代码中也可以这样去实现。

很多时候,爬虫中携带的headers字段,cookie字段,url参数,post的参数很多,不清楚哪些有用,哪些没用的情况下,只能够去尝试,因为每个网站都是不相同的。当然在盲目尝试之前,可以参考别人的思路,我们自己也应该有一套尝试的流程。

1. 通过headers字段来反爬

1.1 通过headers中的User-Agent字段来反爬

通过User-Agent字段反爬的话,只需要给他在请求之前添加User-Agent即可,更好的方式是使用User-Agent池来解决,我们可以考虑收集一堆User-Agent的方式,或者是随机生成User-Agen

1.2 通过referer字段或者是其他字段来反爬

通过referer字段来反爬,我们只需要添加上即可

1.3 通过cookie来反爬

  • 如果目标网站不需要登录 每次请求带上前一次返回的cookie,比如requests模块的session

  • 如果目标网站需要登录 准备多个账号,通过一个程序获取账号对应的cookie,组成cookie池,其他程序使用这些cookie

2.通过js来反爬

2.1 通过js实现跳转来反爬

在请求目标网站的时候,我们看到的似乎就请求了一个网站,然而实际上在成功请求目标网站之前,中间可能有通过js实现的跳转,我们肉眼不可见,这个时候可以通过点击perserve log按钮实现观察页面跳转情况

在这些请求中,如果请求数量很多,一般来讲,只有那些response中带cookie字段的请求是有用的,意味着通过这个请求,对方服务器有设置cookie到本地

2.2 通过js生成了请求参数

对应的需要分析js,观察加密的实现过程

可以使用selenium模块解决

3.3 通过js实现了数据的加密

对应的需要分析js,观察加密的实现过程,也是使用selenium模块实现

3. 通过验证码来反爬

通过打码平台或者是机器学习的方法识别验证码,其中打码平台廉价易用,建议使用

4. 通过ip地址来反爬

同一个ip大量请求了对方服务器,有更大的可能性会被识别为爬虫,对应的通过购买高质量的ip的方式能够解决

5. 其他的反爬方式

6.1 通过自定义字体来反爬

解决思路:可以尝试切换到手机版试试

6.2 通过css来反爬

如通过css掩盖真实数据

解决思路:计算css的偏量

 

转载于:https://www.cnblogs.com/skaarl/p/9658401.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值