php 自定义exception,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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值