PHP自定义异常处理函数
我们常需要根据项目的不同,对代码运行日志记录有不同的需求。这不同的需求包含,需要记录的内容不同、记录的格式不同、日志的输出方式(写如文件、发EMail、发短信等)不同。这时,我们可以将自己的日志记录需求实现方法定义到一个类中,然后再通过下面这些函数,将类的方法注册到对应的事件,这样当事件发生时,系统自定会按我们的需求将日志记录到指定的地方。
一、register_shutdown_function函数:
register_shutdown_function()函数用来设置当PHP脚本执行完成、或者exit()退出时要调用的函数。
二、set_error_handler函数:
set_error_handler函数使用来设置脚本发生错误时调用的函数,用法如下:
三、set_exception_handler函数:
简单示例:
一、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("发生异常啦");