zoukankan      html  css  js  c++  java
  • 自制模仿apache访问日志文件格式的php日志类

    <?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." ";

            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();
    ?>
  • 相关阅读:
    AD7606笔记
    转Keil 中使用 STM32F4xx 硬件浮点单元
    旋转编码器
    PT100/PT1000
    电压跟随器
    段式液晶驱动方法
    物联网的架构
    物联网的操作系统
    C8051开发环境
    解决time命令输出信息的重定向问题
  • 原文地址:https://www.cnblogs.com/lykbk/p/rdtreterert546465656565.html
Copyright © 2011-2022 走看看