免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1109 | 回复: 0
打印 上一主题 下一主题

访问日志统计 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-31 11:16 |只看该作者 |倒序浏览
目的:前阶段发现公司老是有人在访问我的测试网站,就写了这个IP统计函数。
功能:对APACHE的ACCESS.LOG访问日志进行IP统计,实现了按访问次数排序,和按最近一次访问时间排序。

##################################
###############函数部分###########
function Format2UnixTime ($str)
{
    /*
    该函数为格式转换函数,将类似的:$str = "03/Mar/2005:16:53:32"转化为相应的UNIX时间戳。
    */
    $time = $str;
    $time = str_replace("/"," ",$time);
    $time_array = explode( ":",$time,2);
    $time = $time_array[0]." ".$time_array[1];
    return strtotime($time);
}
function CompareByTimes ($x,$y)
{
    if ( $x[0] == $y[0] )
        return 0;
    else if ($x[0] > $y[0])
        return -1;
    else
        return 1;
}
function CompareByAccessTime ($x,$y)
{
    $x[1] = Format2UnixTime($x[1]);  //先格式化为UNIX时间戳
    $y[1] = Format2UnixTime($y[1]); //先格式化为UNIX时间戳
    if ( $x[1] == $y[1] )
        return 0;
    else if ($x[1] > $y[1])
        return -1;
    else
        return 1;
}
/*主函数GetAccessByLog
$filename为文件路径,
$order为排序方式:
             0:按访问次数排序(缺省值)
      1:按最近一次访问的时间排序。
*/
function GetAccessByLog ($filename,$order=0)
{
if ( file_exists($filename) )
{
  $handle = fopen ($filename, "r");
  $ip_times = array();
        while (!feof ($handle)) {
   $buffer = fgets($handle, 999);
   if ((preg_match("#d{1,2}/w{1,3}/d{1,4}:d{1,2}:d{1,2}:d{1,2}#",$buffer,$access_time)) && (preg_match("#d{1,3}.d{1,3}.d{1,3}.d{1,3}#",$buffer,$ip)))
    {
    $ip = $ip[0];
    $access_time = $access_time[0];
    if ( in_array($ip,array_keys($ip_times)))
     {
     $ip_times[$ip][0]++;   // $ip_times[$ip][0]为访问次数times
     $ip_times[$ip][1]=$access_time;   //$ip_times[$ip][1]为访问时间access_time
     }else
      {
      $ip_times[$ip][0] = 1;
      $ip_times[$ip][1]=$access_time;
      }
    }
   }
   fclose ($handle);
}else
{
  echo "The log file does not exist.";
  exit;
}
    if ( $order==1 )
{
  $compare = "CompareByAccessTime";    //按最近一次访问时间排序
  $title = "按最近一次访问时间排序";
    }else{
  $compare = "CompareByTimes";             //按访问次数排序
  $title = "按访问次数排序";
}
     uasort( $ip_times, $compare );  
     
  echo "".$title."";
     foreach (  $ip_times as $ip=>$value )
   {
   echo "IP:".$ip."
访问次数:".$value[0].",最近一次访问时间是:".$value[1]."
";
   }
}
###################################
###################################
###########  Example  ################
$filename = "C:/Apache2/logs/access.log";
GetAccessByLog($filename,0);
// 参数二意义   0:按访问次数排序(缺省值);1:按最近一次访问的时间排序。

?>


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/12569/showart_64406.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP