PHP记录搜索引擎蜘蛛访问网站足迹的方法
本文实例讲述了PHP记录搜索引擎蜘蛛访问网站足迹的方法。分享给大家供大家参考。具体分析如下:
搜索引擎的蜘蛛访问网站是通过远程抓取页面来进行的,我们不能使用JS代码来取得蜘蛛的Agent信息,但是我们可以通过image标签,这样我们就可以得到蜘蛛的agent资料了,通过对agent资料的分析,就可以确定蜘蛛的种类、性别等因素,我们在通过数据库或者文本来记录就可以进行统计了。
数据库结构:
以下为引用的内容:
# #表的结构`naps_stats_bot` # CREATETABLE`naps_stats_bot`( `botid`int(10)unsignedNOTNULLauto_increment, `botname`varchar(100)NOTNULLdefault'', `botagent`varchar(200)NOTNULLdefault'', `bottag`varchar(100)NOTNULLdefault'', `botcount`int(11)NOTNULLdefault'0', `botlast`datetimeNOTNULLdefault'0000-00-0000:00:00', `botlasturl`varchar(250)NOTNULLdefault'', UNIQUEKEY`botid`(`botid`), KEY`botname`(`botname`) )TYPE=MyISAMAUTO_INCREMENT=9; # #导出表中的数据`naps_stats_bot` # INSERTINTO`naps_stats_bot`VALUES(1,'Googlebot','Googlebot/2.X(+http://www.googlebot.com/bot.html)','googlebot',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(2,'MSNbot','MSNBOT/0.1(http://search.msn.com/msnbot.htm)','msnbot',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(3,'InktomiSlurp','Slurp/2.0','slurp',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(4,'Baiduspider','Baiduspider+(+http://www.baidu.com/search/spider.htm)','baiduspider',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(5,'Yahoobot','Mozilla/5.0+(compatible;+Yahoo!+Slurp;+http://help.yahoo.com/help/us/ysearch/slurp)','slurp',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(6,'Sohubot','sohu-search','sohu-search',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(7,'Lycos','Lycos/x.x','lycos',0,'0000-00-0000:00:00',''); INSERTINTO`naps_stats_bot`VALUES(8,'Robozilla','Robozilla/1.0','robozilla',0,'0000-00-0000:00:00','');
PHP程序如下:
以下为引用的内容:
<?php
/************************
*NAPS--NetworkArticlePublishSystem
*----------------------------------------------
*bot.php
*-------------------
*begin:2004-08-15
*
************************/
/************************
*
*Thisprogramisfreesoftware;youcanredistributeitand/ormodify
*itunderthetermsoftheGNUGeneralPublicLicenseaspublishedby
*theFreeSoftwareFoundation;eitherversion2oftheLicense.
*
************************/
/************************
*
*NAPS产品是自由软件。你可以且必须根据《GNUGPL-GNU通用公共许可证》的相关规定
*复制、修改及分发NAPS产品。任何以NAPS产品为基础的衍生发行版未必须经过飘飘的授权。
*
************************/
error_reporting(E_ALL&~E_NOTICE);
functionget_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';
}
returnfalse;
}
$tlc_thispage=addslashes($_SERVER['HTTP_USER_AGENT']);
//添加蜘蛛的抓取记录
$searchbot=get_naps_bot();
if($searchbot){
$DB_naps->query("UPDATEnaps_stats_botSETbotcount=botcount+1,botlast=NOW(),botlasturl='$tlc_thispage'WHEREbotname='$searchbot'");
}
?>
希望本文所述对大家的php程序设计有所帮助。