我爱编程

常见反爬虫与应对措施

2017-12-16  本文已影响773人  小明与小明

反爬虫及其应对措施

常见的反爬措通常来说有三种:

我们来具体分析分析。一般来说,前面两种比较容易遇到,而且大多数也是根据前面两种方式来做反爬的。

通过Header反爬虫

根据用户请求的Headers反爬虫是最常见的反爬虫策略。对于以很低速率爬起网站,难以通过服务器负载统计觉察的爬虫,可以通过User-Agent信息来识别。很多网站都会对Headers的User-Agent进行检测,还有一部分网站会对Referer进行检测(一些资源网站的防盗链就是检测Referer)。

比如,在之前爬取猫眼top100的电影的时候爬取猫眼top100,猫眼就通过headers反爬。

headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.79 Safari/537.36'}

根据用户行为反爬虫

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

动态页面的反爬虫

上面两中反爬虫基本都是在静态页面中出现,但是还有的网站是经过JS渲染的,或者是通过ajax请求得到。

如果能够找到ajax请求,也能分析出具体的参数和响应的具体含义,我们就能采用上面的方法,直接利用requests或者urllib2模拟ajax请求,对响应的json进行分析得到需要的数据。
能够直接模拟ajax请求获取数据固然是极好的,但是有些网站把ajax请求的所有参数全部加密了。我们根本没办法构造自己所需要的数据的请求。遇到这样的网站,我们就不能用上面的方法了,

调用浏览器内核,并利用phantomJS执行js来模拟人为操作以及触发页面中的js脚本。从填写表单到点击按钮再到滚动页面,全部都可以模拟,不考虑具体的请求和响应过程,只是完完整整的把人浏览页面获取数据的过程模拟一遍。
用这套框架几乎能绕过大多数的反爬虫,phantomJS就是一个没有界面的浏览器,只是操控这个浏览器的不是人。

上一篇 下一篇

猜你喜欢

热点阅读