如何准确判断请求是搜索引擎爬虫(蜘蛛)发出的请求?

网站常常会被各类爬虫光顾,有的是搜索引擎爬虫,有的不是,一般状况下这些爬虫都有UserAgent,而咱们知道UserAgent是能够假装的,UserAgent的本质是Http请求头中的一个选项设置,经过编程的方式能够给请求设置任意的UserAgent。 python

因此经过UserAgent判断请求的发起者是不是搜索引擎爬虫(蜘蛛)的方式是不靠谱的,更靠谱的方法是经过请求者的ip对应的host主机名是不是搜索引擎本身家的host的方式来判断。linux

要得到ip的host,在windows下能够经过nslookup命令,在linux下能够经过host命令来得到,例如:web

这里我在windows下执行了nslookup ip 的命令,从上图能够看到这个ip的主机名是crawl-66-249-64-119.googlebot.com。 这说明这个ip是一个google爬虫,google爬虫的域名都是 xxx.googlebot.com.编程

咱们也能够经过python程序的方式来得到ip的host信息,代码以下:c#

复制代码
import socket
def getHost(ip):
    try:
        result=socket.gethostbyaddr(ip)
        if result: return result[0], None
    except socket.herror,e:
        return None, e.message
复制代码

上述代码使用了socket模块的gethostbyaddr的方法得到ip地址的主机名。windows

经常使用蜘蛛的域名都和搜索引擎官网的域名相关,例如:socket

  • 百度的蜘蛛一般是baidu.com或者baidu.jp的子域名
  • google爬虫一般是googlebot.com的子域名
  • 微软bing搜索引擎爬虫是search.msn.com的子域名
  • 搜狗蜘蛛是crawl.sogou.com的子域名

基于以上原理,我写了一个工具页面提供判断ip是不是真实搜索引擎的工具页面,该页面上提供了网页判断的工具和常见的google和bing的搜索引擎爬虫的ip地址。ide

页面地址:http://outofmemory.cn/tools/is-search-engine-spider-ip/ 工具

本文提供的代码是python代码,经过c#代码也是能够实现的,原理是同样的。网站

附带常见搜索引擎蜘蛛的IP段:

蜘蛛名称 IP地址
Baiduspider

202.108.11.* 220.181.32.* 58.51.95.* 60.28.22.* 61.135.162.* 61.135.163.* 61.135.168.*

YodaoBot

202.108.7.215 202.108.7.220 202.108.7.221

Sogou web spider

219.234.81.* 220.181.61.*

Googlebot

203.208.60.*

Yahoo! Slurp

202.160.181.* 72.30.215.* 74.6.17.* 74.6.22.*

Yahoo ContentMatch Crawler

119.42.226.* 119.42.230.*

Sogou-Test-Spider

220.181.19.103 220.181.26.122

Twiceler

38.99.44.104 64.34.251.9

Yahoo! Slurp China

202.160.178.*

Sosospider 124.115.0.*
CollapsarWEB qihoobot

221.194.136.18

NaverBot

202.179.180.45

Sogou Orion spider

220.181.19.106 220.181.19.74

Sogou head spider

220.181.19.107

SurveyBot

216.145.5.42 64.246.165.160

Yanga WorldSearch Bot v

77.91.224.19 91.205.124.19

baiduspider-mobile-gate

220.181.5.34 61.135.166.31

discobot

208.96.54.70

ia_archiver 209.234.171.42
msnbot

65.55.104.209 65.55.209.86 65.55.209.96

sogou in spider

220.181.19.216

相关文章
相关标签/搜索