Maison >développement back-end >tutoriel php >PHP implémente une classe de traitement de journaux simple
Cet article présente principalement l'implémentation d'une classe de traitement de journaux simple en PHP, qui a une certaine valeur de référence. Maintenant, je la partage avec tout le monde. Les amis dans le besoin peuvent s'y référer
<?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); } } } ?>
<br/>
.
Méthode d'appel :
$logHandler= new CLogFileHandler(ROOTPATH . '/logs/'.date('Y-m-d' ).'. log');
$log = Log::Init($logHandler, 15);
Log::DEBUG( var_export($response, true) );
Recommandations associées :
Système de collecte de journaux implémenté en PHP
Méthode de génération d'affiches promotionnelles implémentée en PHP
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!