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