PHP实现一个简单的日志处理类
程序员文章站
2022-03-15 15:24:08
...
这篇文章主要介绍了PHP实现一个简单的日志处理类,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下
<?php //以下为日志 interface ILogHandler { public function write($msg); } class CLogFileHandler implements ILogHandler { private $handle = null; public function __construct($file = '') { $this->handle = fopen($file,'a'); } public function write($msg) { fwrite($this->handle, $msg, 4096); } public function __destruct() { fclose($this->handle); } } class Log { private $handler = null; private $level = 15; private static $instance = null; private function __construct(){} private function __clone(){} public static function Init($handler = null,$level = 15) { if ( ! self::$instance instanceof self ) { self::$instance = new self(); self::$instance->__setHandle($handler); self::$instance->__setLevel($level); } return self::$instance; } private function __setHandle($handler){ $this->handler = $handler; } private function __setLevel($level) { $this->level = $level; } public static function DEBUG($msg) { self::$instance->write(1, $msg); } public static function WARN($msg) { self::$instance->write(4, $msg); } public static function ERROR($msg) { $debugInfo = debug_backtrace(); $stack = "["; foreach($debugInfo as $key => $val){ if(array_key_exists("file", $val)){ $stack .= ",file:" . $val["file"]; } if(array_key_exists("line", $val)){ $stack .= ",line:" . $val["line"]; } if(array_key_exists("function", $val)){ $stack .= ",function:" . $val["function"]; } } $stack .= "]"; self::$instance->write(8, $stack . $msg); } public static function INFO($msg) { self::$instance->write(2, $msg); } private function getLevelStr($level) { switch ($level) { case 1: return 'debug'; break; case 2: return 'info'; break; case 4: return 'warn'; break; case 8: return 'error'; break; default: } } protected function write($level,$msg) { if(($level & $this->level) == $level ) { $msg = '['.date('Y-m-d H:i:s').']['.$this->getLevelStr($level).'] '.$msg."\n"; $this->handler->write($msg); } } } ?>
调用方式:
$logHandler= new CLogFileHandler(ROOTPATH . '/logs/'.date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);
Log::DEBUG( var_export($response, true) );
相关推荐:
以上就是PHP实现一个简单的日志处理类的详细内容,更多请关注其它相关文章!
上一篇: select的option叠加问题