【转】PHP错误处理写入日志记录

<?php
/**
* PHP错误处理写入日志记录
* @author: lnnujxxy
* @time: 2009-09-23
* //使用方法:
* require './error_handler.php';
* $errorHandler = ErrorHandler::getInstance();
* $errorHandler->logFile = dirname(__FILE__).'/log.php';
* $errorHandler->level = array(E_ERROR, E_WARNING);
* 此时PHP运行有错误发生,错误日志将记录到制定日志目录(需要保证PHP有对日志所在目录操作权限)
* 注:记录错误的级别可以根据需要修改。
*/
class ErrorHandler {
public static $instance = null;
public static $var;
private static $logFile = '';
private static $level = array();

public function __construct() {

   set_error_handler(array('ErrorHandler', 'errorHandler'));
}

public function __set($var, $val) {
   self::$$var = $val;
}

public function __get($var) {
   if(isset(self::$$var)) {
      return self::$$var;
   } else {
      throw new Exception("Property $var does not exist");
   }
}

public static function getInstance(){
   if(self::$instance === null) {
      self::$instance = new self();
   }
   return self::$instance;
}

public static function errorHandler($error,$message,$file,$line) {
   if($error && in_array($error, self::$level)) {
    $log=array();
    switch($error) {
     case E_ERROR:
      $type='ERROR';
      break;
     case E_WARNING:
      $type='WARNING';
      break;
     case E_NOTICE:
      $type='NOTICE';
      break;
     default:
      $type='Unknown error type ['.$error.']';
      break;
    }
    $log[] = date('Y-m-d H:i:s', time())."\t".$type.': '.$message.' in line '.$line.' of file '.$file.', PHP '.PHP_VERSION.' ('.PHP_OS.')';
    if(function_exists('debug_backtrace')) {
     $backtrace=debug_backtrace();
     for($level=1;$level<count($backtrace);$level++) {
      $message='File: '.$backtrace[$level]['file'].' Line: '.$backtrace[$level]['line'].' Function: ';
      if(IsSet($backtrace[$level]['class']))
       $message.='(class '.$backtrace[$level]['class'].') ';
      if(IsSet($backtrace[$level]['type']))
       $message.=$backtrace[$level]['type'].' ';
      $message.=$backtrace[$level]['function'].'(';
      if(IsSet($backtrace[$level]['args'])) {
       for($argument=0;$argument<count($backtrace[$level]['args']);$argument++) {
        if($argument>0)
         $message.=', ';
        $message.=serialize($backtrace[$level]['args'][$argument]);
       }
      }
      $message.=')';
      $log[]=$message;
     }
    }
    self::writeLog(self::$logFile, $log);
   }
}

public static function writeLog($logFile, $log) {
   if(file_exists($logFile) && filesize($logFile) > 2048000) { //2M一个日志文件
    $logDir = $logFileBak = $file = '';
    $logDir = dirname($logFile);
    $file = basename($logFile);
    $logFileBak = $logDir.'/'.$file.date('Y-m-d-H-i-s', time()).'.php';
    rename($logFile, $logFileBak);
   }
   if($fp = fopen($logFile, 'a')) {
    flock($fp, 2);
    $log = is_array($log) ? $log : array($log);
    foreach($log as $tmp) {
     fwrite($fp, "<?PHP exit;?>\t".str_replace(array('<?', '?>'), '', $tmp)."\n");
    }
    fclose($fp);
   }
}
}

/*
$errorHandler = ErrorHandler::getInstance();
$errorHandler->logFile = dirname(__FILE__).'/log.php';
$errorHandler->level = array(E_ERROR, E_WARNING);
str_replace(asdasdf);
*/
?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值