我有一个网站项目,统计某些网页的浏览量。我将这些视图存储为ip地址和日期,因此我知道当用户在该页面上单击几次时,它只计算1次。
问题是,当搜索机器人访问我的网站时,我也想从真正的用户中删除搜索机器人。
我通常在其他站点上这样做,方法是将IP转换为真实地址,并与字符串“google”等进行比较。
但有时需要3-4秒才能转换成真正的地址,这使得我的网站速度变慢了。
我如何处理这个问题呢?
更新
我做了更多的研究,我想出了这个简单的解决方案(基于你的答案)。
$global_bots = array("bot", "slurp", "spider", "crawl", "archiver", "facebook");//此变量位于我的全局设置文件中,该文件包含在我的所有文件中。
$user_agent = $_SERVER['HTTP_USER_AGENT'];
$bot_count = 0;
do{
$pos = stripos($user_agent, $global_bots[$bot_count]);
$bot_count++;
}while($pos===false && ( $bot_count < count($global_bots) ) );
if($pos!==false){
//check if user already clicked today on this page, else record his ip
}else{
//don't record it, it's mostly a BOT
}如果您对此有任何其他更新,如在机器人中找到字符串,请随意跳入其中,并提供快速答案。
谢谢。
发布于 2013-04-28 19:14:30
它不是“转换”(从数学意义上讲):它是对外部数据库( DNS服务器)的查找。您应该使用与任何其他外部服务查找相同的规则:
一旦你知道了这一点,我谦逊的建议是你不要这样做:
区分机器人的常用(非排他性)方法是:
您可能可以借用用户代理数据库(甚至用户代理检测库)。
发布于 2013-04-28 19:09:55
行为良好的机器人会首先请求/robots.txt路径,而人类通常根本不会请求它。因此,您可以通过查找首先请求此路径的用户代理来识别机器人。
https://stackoverflow.com/questions/16266590
复制相似问题