首页 > 开发 > PHP > 正文

浅谈php自定义错误日志

2024-05-04 22:39:13
字体:
来源:转载
供稿:网友

平时经常看php的错误日志,很少有机会去自己动手写日志,看了王健的《最佳日志实践》觉得写一个清晰明了,结构分明的日志还是非常有必要的。

在写日志前,我们问问自己:为什么我们有时要记录自定义的日志呢?而不用系统默认的日志记录方式呢?

我认为有两个原因:

1.团队需要一个统一格式的日志方便管理

2.大量无用错误日志占据硬盘空间,仅需记录有意义的日志。

 那么,实践一下。

1.打开你的php.ini

 2.打开日志记录,将

代码如下:
log_errors = Off

改成

代码如下:
log_errors = On

3.将php.ini保存退出并重启web服务器

4.在你的代码最前面加上如下代码

代码如下:
<?php
//错误处理函数
function myErrorHandler($errno, $errstr, $errfile, $errline)
{
    $log_file = "./php_%s_log_".date("Ymd").".log";//定义日志文件存放目录和文件名
    $template = '';
    switch ($errno) {
    case E_USER_ERROR:
        $template .= "用户ERROR级错误,必须修复 错误编号[$errno] $errstr ";
        $template .= "错误位置 文件$errfile,第 $errline 行/n";
        $log_file = sprintf($log_file,'error');
        exit(1);//系统退出
        break;
    case E_USER_WARNING:
        $template .= "用户WARNING级错误,建议修复 错误编号[$errno] $errstr ";
        $template .= "错误位置 文件$errfile,第 $errline 行/n";
        $log_file = sprintf($log_file,'warning');
        break;
    case E_USER_NOTICE:
        $template .= "用户NOTICE级错误,不影响系统,可不修复 错误编号[$errno] $errstr ";
        $template .= "错误位置 文件$errfile,第 $errline 行/n";
    $log_file = sprintf($log_file,'notice');
        break;
    default:
        $template .= "未知错误类型: 错误编号[$errno] $errstr  ";
        $template .= "错误位置 文件$errfile,第 $errline 行/n";
        $log_file = sprintf($log_file,'unknown');
        break;
    }
    file_put_contents($log_file,$template,FILE_APPEND);

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表