通过PHP判断搜索引擎蜘蛛是否访问你的网站

简介:
< DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd>



搜索引擎的蜘蛛访问网站是通过远程抓取页面来进行的,我们不能使用JS代码来取得蜘蛛的Agent信息,但是我们可以通过image标签,这样我们就可以得到蜘蛛的agent资料了,通过对agent资料的分析,就可以确定蜘蛛的种类、性别等因素,我们在通过数据库或者文本来记录就可以进行统计了。
数据库结构:

#
# 表的结构 `naps_stats_bot`
#

Create TABLE `naps_stats_bot` (
`botid` int(10) unsigned NOT NULL auto_increment,
`botname` varchar(100) NOT NULL default ‘’,
`botagent` varchar(200) NOT NULL default ‘’,
`bottag` varchar(100) NOT NULL default ‘’,
`botcount` int(11) NOT NULL default ‘0&prime;,
`botlast` datetime NOT NULL default ‘0000-00-00 00:00:00&prime;,
`botlasturl` varchar(250) NOT NULL default ‘’,
UNIQUE KEY `botid` (`botid`),
KEY `botname` (`botname`)
) TYPE=MyISAM AUTO_INCREMENT=9 ;

#
# 导出表中的数据 `naps_stats_bot`
#

Insert INTO `naps_stats_bot` VALUES (1, ‘Googlebot’, ‘Googlebot/2.X (+http://www.googlebot.com/bot.html)’, ‘googlebot’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (2, ‘MSNbot’, ‘MSNBOT/0.1 (http://search.msn.com/msnbot.htm)’, ‘msnbot’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (3, ‘Inktomi Slurp’, ‘Slurp/2.0&prime;, ’slurp’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (4, ‘Baiduspider’, ‘Baiduspider+(+http://www.baidu.com/search/spider.htm)’, ‘baiduspider’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (5, ‘Yahoobot’, ‘Mozilla/5.0+(compatible;+Yahoo!+Slurp;+http://help.yahoo.com/help/us/ysearch/slurp)’, ’slurp’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (6, ‘Sohubot’, ’sohu-search’, ’sohu-search’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (7, ‘Lycos’, ‘Lycos/x.x’, ‘lycos’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);
Insert INTO `naps_stats_bot` VALUES (8, ‘Robozilla’, ‘Robozilla/1.0&prime;, ‘robozilla’, 0, ‘0000-00-00 00:00:00&prime;, ‘’);

PHP程序:

<?php

  

  

  
error_reporting(E_ALL & ~E_NOTICE);
  
function get_naps_bot()
{
         $useragent = strtolower($_SERVER['HTTP_USER_AGENT']);
                        
         if (strpos($useragent, 'googlebot') !== false){
                 return 'Googlebot';
         }
        
         if (strpos($useragent, 'msnbot') !== false){
                 return 'MSNbot';
         }
        
         if (strpos($useragent, 'slurp') !== false){
                 return 'Yahoobot';
         }
        
         if (strpos($useragent, 'baiduspider') !== false){
                 return 'Baiduspider';
         }
        
         if (strpos($useragent, 'sohu-search') !== false){
                 return 'Sohubot';
         }
        
         if (strpos($useragent, 'lycos') !== false){
                 return 'Lycos';
         }
        
         if (strpos($useragent, 'robozilla') !== false){
                 return 'Robozilla';
         }        
         return false;
}
  
$tlc_thispage = addslashes($_SERVER['HTTP_USER_AGENT']);
//添加蜘蛛的抓取记录
$searchbot = get_naps_bot();
if ($searchbot) {
         $DB_naps->query("Update naps_stats_bot SET botcount=botcount+1, botlast=NOW(), botlasturl='$tlc_thispage' Where botname='$searchbot'");
}
  
?>

本文转自 netcorner 博客园博客,原文链接: http://www.cnblogs.com/netcorner/archive/2007/08/03/2912321.html ,如需转载请自行联系原作者

相关文章
|
4月前
|
程序员 网络安全 PHP
IIS使用PHPManager发布PHP网站
PHPManager是一款用于IIS(Internet Information Services)的工具,旨在简化在Windows服务器上发布PHP网站的过程。通过PHPManager,用户可以轻松管理PHP版本、配置PHP设置以及进行PHP应用程序的部署。这个工具提供了直观的用户界面,使用户能够更方便地与IIS服务器进行交互,而不需要深入了解服务器配置的技术细节。PHPManager的使用使得在IIS环境中托管和维护PHP网站变得更加便捷,提高了网站的部署效率和管理灵活性。
37 0
|
4月前
|
网络安全 PHP 开发者
IIS服务器发布PHP网站
IIS服务器,相信开发者都不会陌生,它的英文全称是Internet Information Services,是由微软公司提供的基于运行Microsoft Windows的互联网基本服务,常用于Windows系统的Web项目部署,本篇以PHP项目为例,讲解如何使用IIS完成PHP项目的发布。
57 0
|
4月前
|
JavaScript 数据可视化 IDE
分享21个广告排行、15个交友会员、25个网站导航和39个文件管理PHP源码,总有一款适合你
分享21个广告排行、15个交友会员、25个网站导航和39个文件管理PHP源码,总有一款适合你
44 0
分享21个广告排行、15个交友会员、25个网站导航和39个文件管理PHP源码,总有一款适合你
|
8月前
|
存储 自然语言处理 搜索推荐
php 外贸代购系统网站
php 外贸代购系统网站
75 0
|
20天前
|
存储 SQL 缓存
记录如何用php做一个网站访问计数器的方法
创建简单网站访问计数器,可通过存储访问次数的文件或数据库。首先,创建`counter.txt`存储计数,然后在`counter.php`中编写PHP代码以读取、增加并显示计数,使用`flock`锁定文件避免并发问题。网页通过包含`counter.php`展示计数。对于高流量网站,推荐使用数据库确保原子性和并发处理能力,或利用缓存提升性能。注意,实际生产环境可能需更复杂技术防止作弊。
|
2月前
|
PHP 数据安全/隐私保护
PHP页面如何实现设置独立访问密码
PHP网页如果需要查看信息必须输入密码,验证后才可显示出内容的代码如何实现? 对某些php页面设置单独的访问密码,如果密码不正确则无法查看内容,相当于对页面进行了一个加密
15 2
PHP页面如何实现设置独立访问密码
|
4月前
|
PHP
HYBBS 表白墙网站PHP程序源码 可封装成APP
HYBBS 表白墙网站PHP程序源码 可封装成APP
37 1
|
4月前
|
前端开发 PHP
IIS发布PHP网站常见错误:字体库404
笔者最近在用IIS发布php网站时,前端出现了字体库文件404的错误,关于这个问题,尝试了很多办法,最终发现是字体文件类型不被IIS识别导致的,解决方法是在config文件中添加映射配置,下面我就来详细介绍下。
36 5