|
发表于 2017-11-15 08:15:04
|
显示全部楼层
|阅读模式
来自 中国–河南–新乡
方法定义文件:\source\function\function_core.php
checkrobot()代码如下:
- function checkrobot($useragent = '') {
- static $kw_spiders = array('bot', 'crawl', 'spider' ,'slurp', 'sohu-search', 'lycos', 'robozilla');
- static $kw_browsers = array('msie', 'netscape', 'opera', 'konqueror', 'mozilla');
- $useragent = strtolower(empty($useragent) ? $_SERVER['HTTP_USER_AGENT'] : $useragent);
- if(strpos($useragent, 'http://') === false && dstrpos($useragent, $kw_browsers)) return false;
- if(dstrpos($useragent, $kw_spiders)) return true;
- return false;
- }
复制代码
函数说明:
本函数通过分析全局变量$_SERVER中的$_SERVER['HTTP_USER_AGENT']根据$useragent关键词判断该访问是否是蜘蛛(机器人),当然由于只是关键词匹配,所以还是存在一定的误判,有兴趣的可以对此方法进行改进;
使用方法举例:
- if(checkrobot()){
- //是蜘蛛(机器人),执行流程
- }else{
- //不是是蜘蛛(机器人),执行流程
- }
复制代码
|
|