> php教程 > php手册 > 一个简单的自定义日志记录功能

一个简单的自定义日志记录功能

WBOY
풀어 주다: 2016-06-07 11:45:21
원래의
1406명이 탐색했습니다.

有时候我们需要记录一些自定义的“错误信息”,而不是系统错误,显然,PHP自带的error_log是不合适的。这里小弟简单写了个自由记录“日志”的函数,仅供参考
使用:writelog("myerror","错误信息");
/**<br>  *日志记录,按照"Ymd.log"生成当天日志文件<br>  * 日志路径为:入口文件所在目录/logs/$type/当天日期.log.php,例如 /logs/error/20120105.log.php<br>  * @param string $type 日志类型,对应logs目录下的子文件夹名<br>  * @param string $content 日志内容<br>  * @return bool true/false 写入成功则返回true<br>  */<br> function writelog($type="",$content=""){<br>     if(!$content || !$type){<br>         return FALSE;<br>     }    <br>     $dir=getcwd().DIRECTORY_SEPARATOR.'logs'.DIRECTORY_SEPARATOR.$type;<br>     if(!is_dir($dir)){ <br>         if(!mkdir($dir)){<br>             return false;<br>         }<br>     }<br>     $filename=$dir.DIRECTORY_SEPARATOR.date("Ymd",time()).'.log.php';   <br>     $logs=include $filename;<br>     if($logs && !is_array($logs)){<br>         unlink($filename);<br>         return false;<br>     }<br>     $logs[]=array("time"=>date("Y-m-d H:i:s"),"content"=>$content);<br>     $str="<?php \r\n return ".var_export($logs, true).";";<br />     if(!$fp=@fopen($filename,"wb")){<br>         return false;<br>     }           <br>     if(!fwrite($fp, $str))return false;<br>     fclose($fp);<br>     return true;<br> }要使用本函数,你需要做以下几件事:
1.将这个函数放到你的函数库中,比如tp的common.php里,自动加载.
2.在你的入口文件所在目录下,新建logs目录,并且有写入权限。

然后你就可以在模块中这样使用:
writelog("myerror","错误信息");
会自动在logs目录下生成myerror子目录,并以当天日期为名创建日志文件。
日志的格式是一个二维数组:
array(
0=>array('记录时间','日志信息'),
1=>array('记录时间','日志信息'),
……
)
要读取日志,只需要
$arr=include '日志文件';
或者你可以自己写一个 getlog()的方法。

AD:真正免费,域名+虚机+企业邮箱=0元

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿