日期:2013-03-15 浏览次数:20494 次
<?php
/*
* 1.Singleton Pattern for the log of application
* 2.建议将类文件名写成class.log.php
* 以便__autoload()自动载入该类
* 3.Author:NoAngels
* 4.E-mail:flare_1023@163.com QQ:82535599
*/
final class log{
#构造函数,日志文件不存在就创建否则就打开文件以供后续使用
private function __construct(){
if(!$this->__fp = @fopen('application.log', 'ab+')){
$this->__errMsg = '创建或读取日志文件失败';
$this->__errorHandler();
}
}
#析构函数,释放资源
function __destruct(){
#站位先
}
#静态函数,配合静态变量使用,实现singleton设计模式
static function getInstance(){
if(self::$__instance == NULL){
self::$__instance = new log;
}
return self::$__instance;
}
#类内部错误处理机制
private function __errorHandler(){
die($this->__errMsg);
}
#将指定内容写入到日志文件中
public function inLog($temp){
if(@fwrite($this->__fp, time()."|||".$temp."\r\n") === FALSE){
$this->__errMsg = '写入到日志文件失败';
$this->__errorHandler();
}
return;
}
#将日志内容输出,参数默认为1,即默认用类内部方法打印日志,否则可自定义显示方式.两种情况下都返回数组
public function outLog($default = 1){
$outArray = array();
while(!feof($this->__fp)){
$line = fgets($this->__fp);
if(strlen($line) != 0){
$tmp = explode("|||", $line, 2);
$outArray[] = $tmp;
}
}
if($default == 1){
$this->__printLog($outArray);
}
return $outArray;