一个简单的开源PHP日志类

原创 2011年01月25日 13:38:00

<?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);
?>

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

一个简单php日志类

日志类如下,news目录为当前php文档根目录下子目录。  <?php if( ! defined('BASEPATH') ) { define ('BASEPATH', $_SERVER['D...

分享一个用了很久的php日志类

<?php class Logs{ private $FilePath; private $FileName; private $m_MaxLogFileNum; pr...

分享一个简单的Android日志文件记录类

import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import j...

关于使用C#编写一个简单的日志类

最近在项目中编写的log类,在博客上记录一下。 在调用的时候会按照当前时间自动生成对应的日志文件。代码如下: using System; using System.Collections.Gene...

一个简单的开源PHP爬虫框架『Phpfetcher』

好久不见了!我终于又写一篇日志了,本来有很多流水帐想发但是感觉没营养,就作罢了。 今天我主要分享一个简单的PHP爬虫框架,名字叫:Phpfetcher 项目的地址是:https://github.c...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)