PHP自定义异常处理函数

  我们常需要根据项目的不同,对代码运行日志记录有不同的需求。这不同的需求包含,需要记录的内容不同、记录的格式不同、日志的输出方式(写如文件、发EMail、发短信等)不同。这时,我们可以将自己的日志记录需求实现方法定义到一个类中,然后再通过下面这些函数,将类的方法注册到对应的事件,这样当事件发生时,系统自定会按我们的需求将日志记录到指定的地方。

一、register_shutdown_function函数:
  register_shutdown_function()函数用来设置当PHP脚本执行完成、或者exit()退出时要调用的函数。
register_shutdown_function(array('Err','shutdown_function'));
  
二、set_error_handler函数:
  set_error_handler函数使用来设置脚本发生错误时调用的函数,用法如下:
set_error_handler(array('Err','error_handler'));
通过 set_error_handler() 函数设置用户自定义的错误处理程序,然后触发错误(通过 trigger_error()):

三、set_exception_handler函数:
set_exception_handler(array('Err','appException'));

简单示例:
<?php
date_default_timezone_set('PRC');
register_shutdown_function(array('Err','successHandle'));
set_error_handler(array('Err','errorHandler'));
set_exception_handler(array('Err','exceptionHandle'));
class Err {
    private static $logFile = 'log.txt';
    //脚本发生错误
    public static function errorHandler($errno, $errstr, $errfile, $errline){
        $msg = sprintf("Error: %s %s %s:%s", $errno, $errstr, $errfile, $errline);
        self::writeLog($msg);
    }

    //脚本执行完成
    public static function successHandle() {
        self::writeLog("Success.");
    }

    //脚本抛出异常
    public static function exceptionHandle($exception) {
        $msg = sprintf("Exception: %s",  $exception->getMessage());
        self::writeLog($msg);
    }

    //写日志
    private static function writeLog( $msg )  {
        $msg = sprintf("%s %s\t%s\n", date('Y-m-d H:i:s'), $_SERVER['REMOTE_ADDR'], $msg);
        file_put_contents(self::$logFile, $msg, FILE_APPEND);
    }
}

throw new Exception("发生异常啦");

0 个评论

要回复文章请先登录注册