码迷,mamicode.com
首页 > Web开发 > 详细

自制模仿apache访问日志文件格式的php日志类

时间:2015-03-31 12:29:08      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:

<?php


// 访问日志写入类 @author 王伟 2011.12.14
class Log{
    
    //项目跟路径
    private $root_path;
    
    //日志文件绝对路径
    private static $log_file_path;
    
    function __construct($root_path){
        $this->root_path = $root_path.DIRECTORY_SEPARATOR;
        self::$log_file_path = $this->root_path .‘logfile‘.DIRECTORY_SEPARATOR .date(‘Y_m_d‘,time()).‘.log‘;
    }
   
    // 获取访问者ip地址
    private static function getRealIp(){
        $ip = false;
        if (!empty($_SERVER["HTTP_CLIENT_IP"])){
            $ip = $_SERVER["HTTP_CLIENT_IP"];
        }
        if (!empty($_SERVER[‘HTTP_X_FORWARDED_FOR‘])){
            $ips = explode (", ", $_SERVER[‘HTTP_X_FORWARDED_FOR‘]);
            if ($ip){
                array_unshift($ips, $ip);
                $ip = false;
            }
            for ($i = 0; $i < count($ips); $i++){
                if (!eregi ("^(10|172\.16|192\.168)\.", $ips[$i])){
                    $ip = $ips[$i];
                    break;
                }
            }
        }
        return ($ip ? $ip : $_SERVER[‘REMOTE_ADDR‘]);
    }
   
    // 写访问日志
    public function writeLog(){
        
        //浏览当前页面的用户的主机名
        $uhost = (isset($_SERVER[‘REMOTE_HOST‘]) ? $_SERVER[‘REMOTE_HOST‘] : ‘-‘);
        
        //请求时间
        $rtime =  date(‘Y-m-d H:i:s‘,$_SERVER[‘REQUEST_TIME‘]);
        
        //请求类型
        $rmethod = $_SERVER[‘REQUEST_METHOD‘];
        
        //请求来路
        $ref = (isset($_SERVER[‘HTTP_REFERER‘]) ? $_SERVER[‘HTTP_REFERER‘] : ‘-‘);
        
        //请求协议类型
        $rprotocol = $_SERVER[‘SERVER_PROTOCOL‘];
        
        //请求浏览器的用户浏览器信息
        $ragent = empty($_SERVER[‘HTTP_USER_AGENT‘]) ? ‘Unknown‘ : $_SERVER[‘HTTP_USER_AGENT‘];
        
        $durl = $_SERVER[‘REQUEST_URI‘];

        $logStr = self::getRealIp() .‘ ‘.$uhost.‘ ‘.$rtime.‘ "‘.$rmethod.‘ ‘.$ref.‘ ‘.$rprotocol.‘" ‘.$ragent.‘ ‘.$durl."\r\n";

        if(!file_exists($this->root_path .‘logfile‘)){
            mkdir($this->root_path .‘logfile‘);    
        }
        
        $flog = fopen(self::$log_file_path,‘a‘);
        fwrite($flog,$logStr);
        fclose($flog);
    }
}
?>

<?php
// 使用说明
// 在new Log类时传入想要生成日志文件的所在目录的绝对路径(注:不含末尾的 "/")
//会在这个目录下创建 logfile目录,并每天按日期命名生成一个访问日志文件

$log = new Log(想要生成日志文件的所在目录的绝对路径);
$log->writeLog();
?>

自制模仿apache访问日志文件格式的php日志类

标签:

原文地址:http://www.cnblogs.com/lykbk/p/rdtreterert546465656565.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!