一个简单的开源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文档根目录下子目录。  
  • lxzo123
  • lxzo123
  • 2011年04月29日 09:56
  • 5326

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

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

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

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

import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import j...
  • jhjava
  • jhjava
  • 2012年02月16日 15:47
  • 929

一个简单的日志类,将打印信息写到文件

因获取当前软件名字和使用互斥锁用了qt的头文件,如不想支持qt,可改成给定文件名,互斥锁可换成windows下或者linux下的互斥锁,或者boost库的锁也行。多线程下写日志会否出现错乱暂未测试,如...

日志类一个简单的C++日志类

  • 2010年02月01日 21:22
  • 3KB
  • 下载

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

转载请注明: 吹水小镇 | reetsee.com 原文链接地址: http://blog.reetsee.com/archives/366 好久不见了!我终于又写一篇日志了,本来有很多流...

python实现一个简单的日志系统

  • 2014年04月19日 19:48
  • 6KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个简单的开源PHP日志类
举报原因:
原因补充:

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