php的异常处理

一、php中的错误分类

        在php中,预定义常量对应不同的错误类型分类(error_type)如下:

1E_ERROR 致命的运行时错误。这类错误一般是不可恢复的情况,例如内存分配导致的问题。后果是导致脚本终止不再继续运行。
2E_WARNING 运行时警告 (非致命错误)。仅给出提示信息,但是脚本不会终止运行。
4E_PARSE 编译时语法解析错误。解析错误仅仅由分析器产生。
8E_NOTICE 运行时通知。表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。
16E_CORE_ERROR 在 PHP 初始化启动过程中发生的致命错误。该错误类似 E_ERROR,但是是由 PHP 引擎核心产生的。
32E_CORE_WARNINGPHP 初始化启动过程中发生的警告 (非致命错误) 。类似 E_WARNING,但是是由 PHP 引擎核心产生的。
64E_COMPILE_ERROR致命编译时错误。类似 E_ERROR,但是是由 Zend 脚本引擎产生的。
128E_COMPILE_WARNING编译时警告 (非致命错误)。类似 E_WARNING,但是是由 Zend 脚本引擎产生的。
256E_USER_ERROR 用户产生的错误信息。类似 E_ERROR,但是是由用户自己在代码中使用 PHP 函数 trigger_error()来产生的。
512E_USER_WARNING 用户产生的警告信息。类似 E_WARNING,但是是由用户自己在代码中使用 PHP 函数 trigger_error()来产生的。
1024E_USER_NOTICE 用户产生的通知信息。类似 E_NOTICE,但是是由用户自己在代码中使用 PHP 函数 trigger_error()来产生的。
2048E_STRICT 启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。PHP 5.4.0 之前的版本中不包含 E_ALL
4096E_RECOVERABLE_ERROR 可被捕捉的致命错误。 它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。 如果该错误没有被用户自定义句柄捕获 (参见 set_error_handler()),将成为一个 E_ERROR 从而脚本会终止运行。自 PHP 5.2.0 起
8192E_DEPRECATED运行时通知。启用后将会对在未来版本中可能无法正常工作的代码给出警告。自 PHP 5.3.0 起
16384E_USER_DEPRECATED用户产生的警告信息。 类似 E_DEPRECATED, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。自 PHP 5.3.0 起
32767E_ALLPHP 5.4.0 之前为 E_STRICT 除外的所有错误和警告信息。不同php版本对应不同整数值。

二、异常处理相关配置

1、error_reporting = error_type  设置显示的错误类型;

        也可通过 函数error_reporting(int $error_type) 在php程序中动态设置。

2、display_errors = Off|On             该选项设置是否将错误信息作为输出的一部分显示到屏幕,或者隐藏;(线上环境建议设置为Off)
    当该值设置为Off时,警告类错误信息将不提示到页面,其他错误会报500错误,不会显示具体的错误信息500 Internal Server Error,但是会记录到错误日志

3、log_errors = Off|On                    该选项设置错误日志开启或关闭

4、log_errors_max_len = 1024        设置错误日志最大长度 

5、error_log = /usr/local/error.log     设置错误日志文件的位置

三、set_error_handler的使用

1、set_error_handler(callable $error_handler, int $error_types = E_ALL | E_STRICT) 该函数可以设置用户自定义的函数 (error_handler) 来处理php程序中出现的错误。

        但是,以下类型的错误不能由用户定义的函数来处理:E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING

2、用户自定义的函数(error_handler)的参数和用法:

error_handler(int $error_type, string $errstr, string $errfile , int $errline , array $errcontext )

$error_type:错误类型

$errstr:错误信息

$errfile:产生错误的文件地址

$errline:产生错误的行号

$errcontext:包含参数和变量信息

四、set_exception_handler 的使用

1、set_exception_handler(callable $exception_handler) 设置默认的异常处理函数。

        该函数能捕获大部分 Error 和 Exception ;但是不能捕获E_WARNING 和E_NOTICE类型的错误。在 exception_handler 调用后异常会中止程序,后面的程序将不再执行。

2、当异常被 try/catch 捕获后。将不再被set_exception_handler捕获了。 try/catch也不会终止程序。

五、trigger_error触发错误

1、trigger_error(string $error_msg, int $error_type = E_USER_NOTICE)设置产生一个用户级别的错误(E_USER 系列常量对应的错误),默认是 E_USER_NOTICE。

error_msg   该 error 的特定错误信息,长度限制在了 1024 个字节。超出会被截断。

error_type   该 error 所特定的错误类型。

2、该函数抛出的错误会被set_error_handler捕获,不会被set_exception_handler捕获。也不会被try/catch 捕获。

六、 捕获异常try/catch/finally

1、语法格式:

try {         // PHP 脚本执行发生错误或手动抛出错误
        throw new Exception('错误信息');
} catch (Exception $e) {        //根据类型捕获错误

}finally{        //return 语句之后还是会执行finally,die和exit后不会执行finally
}

2、大部分的Error 和 Exception异常能被捕获,而warning和notice类的异常不能被捕获;

3、异常分类Error 和 Exception 
        ①、Exception 是通过 throw new Exception() 手动抛出的;如果没用 try/catch不捕获并处理 Exception,程序会终止,并报出 Fatal Error 错误,但 try/catch捕获后程序可以继续执行;被set_exception_handler捕获或会终止程序。
        ②、Error 是在 PHP 脚本执行发生错误时自动触发,用户级别的可以通过 trigger_errors() 抛出;
        ③、Error 和 Exception都实现了 Throwable 接口,都可以通过 catch (Throwable $t) {...} 同时捕获 ;

4、throw 抛出的异常都能被set_exception_handler捕获。


版权声明:本文为jkzyx123原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。