关闭

一个简单的开源PHP日志类

标签: phptimezoneconstructorfpdatefunction
1045人阅读 评论(0) 收藏 举报
分类:

<?php 
/**
 * Logging Class
 *
 * @package  CodeIgniter
 * @subpackage Libraries
 * @category Logging
 * @author  ExpressionEngine Dev Team
 * @link  http://codeigniter.com/user_guide/general/errors.html
 */
class CI_Log {
 
 var $log_path = '../logs/';
 var $_threshold = 3;
 var $_date_fmt = 'Y-m-d H:i:s:ms';
 var $_enabled = TRUE;
 var $_levels = array('ERROR' => '1', 'DEBUG' => '2',  'INFO' => '3', 'ALL' => '4');
   
 /**
  * Constructor
  *
  * @access public
  */
 function CI_Log()
 {
  if ( ! is_dir($this->log_path))
  {
   mkdir($this->log_path, 0777);
  }
 }
 
 // --------------------------------------------------------------------
 
 /**
  * Write Log File
  *
  * Generally this function will be called using the global log_message() function
  *
  * @access public
  * @param string the error level
  * @param string the error message
  * @param bool whether the error is a native PHP error
  * @return bool
  */  
 function write_log($level = 'error', $msg, $php_error = FALSE)
 {  
  if ($this->_enabled === FALSE)
  {
   return FALSE;
  }
 
  $level = strtoupper($level);
  
  if ( ! isset($this->_levels[$level]) OR ($this->_levels[$level] > $this->_threshold))
  {
   return FALSE;
  }
 
  $filepath = $this->log_path.'log-'.date('Y-m-d').'.txt';
  $message  = "/r";
  
  
  if ( ! $fp = @fopen($filepath, 'a+'))
  {
   return FALSE;
  }

  $message .= $level.' '.(($level == 'INFO') ? ' -' : '-').' '.date($this->_date_fmt). ' --> '.$msg."/n";
  
  flock($fp, LOCK_EX); 
  fwrite($fp, $message);
  flock($fp, LOCK_UN);
  fclose($fp);
 
  @chmod($filepath, 0666);   
  return TRUE;
 }

}

?>

 

test-------------------------------------------------------------------------------------------------------------------

 

<?php
  include_once('CI_Log.class.php');
  date_default_timezone_set('PRC');

  $Log = new CI_Log();
  $Log->write_log('debug','->begin',false);
  $Log->write_log('debug','->end',false);
?>

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:714645次
    • 积分:8600
    • 等级:
    • 排名:第2232名
    • 原创:185篇
    • 转载:136篇
    • 译文:1篇
    • 评论:43条
    最新评论