1. 錯誤回報等級 error_reporting()
error_reporting(int $level);
PHP 5.4 以上 E_ALL 包含了 E_STRICT。
PHP Manual 所有的錯誤等級。
範例:
<?php // 关闭所有PHP错误报告 error_reporting(0); // Report simple running errors error_reporting(E_ERROR | E_WARNING | E_PARSE); // 报告 E_NOTICE也挺好 (报告未初始化的变量 // 或者捕获变量名的错误拼写) error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE); // 除了 E_NOTICE,报告其他所有错误 error_reporting(E_ALL ^ E_NOTICE); // 报告所有 PHP 错误 (参见 changelog) error_reporting(E_ALL); // 报告所有 PHP 错误 error_reporting(-1); // 和 error_reporting(E_ALL); 一样 ini_set('error_reporting', E_ALL); ?>
2. 錯誤處理函數 set_error_handler()
set_error_handler(function (int $errno, string $errstr, string $errfile, int $errline) { // ... }, $error_types = E_ALL)
#上述 $error_types 指定的錯誤類型會被該錯誤處理函數攔截( 除非函數回傳了 false)
帶@ 前綴的語句發生錯誤時, $errno 值為0
#腳本會在該處理函數結束後繼續執行(因此必要時需主動呼叫 die() )
#範例:
function handleError($level, $message, $file = '', $line = 0) { if (error_reporting() & $level) { throw new ErrorException($message, 0, $level, $file, $line); } return false; }
將 錯誤 轉換為 異常
注意: 無法捕獲的錯誤
以下層級的錯誤不能由使用者定義的函數來處理:
E_ERROR
<strong><span style="font-size: 14px;">#E_PARSE</span></strong>
<strong><span style="font-size: 14px;">E_CORE_ERROR</span></strong>
<strong><span style="font-size: 14px;">E_CORE_WARNING</span></strong>
#
<strong><span style="font-size: 14px;">E_COMPILE_ERROR</span></strong>
<strong><span style="font-size: 14px;">E_COMPILE_WARNING </span></strong>
在呼叫 set_error_handler()
函數所在檔案中產生的大多數 E_STRICT。
這些無法捕獲的錯誤, 可在 register_shutdown_function() 中處理( 但腳本仍會結束)
<span style="font-size: 14px;"></span>
##3. 异常处理函数 set_exception_handler
// < PHP 7 set_exception_handler('handleException') // < PHP 7 handleException(Exception $ex) { echo "Uncaught exception: " , $ex->getMessage(), "\n"; } // >= PHP 7 handleException(Throwable $ex) { echo "Uncaught exception: " , $ex->getMessage(), "\n"; }
<span style="font-size: 14px;"></span>
在用户自定义异常处理函数内部, 可根据情况做一下处理:
日志记录错误
web 渲染错误页面
console 渲染错误提示
<span style="font-size: 14px;"></span>
4. PHP 中止时执行函数
<span style="font-size: 14px;">register_shutdown_function</span>
register_shutdown_function(function () { }, $para1, $param2, ...)
在用户自定义脚本中止处理函数内部, 可根据情况做一下处理:
判断是否因严重错误而结束脚本(无法被 set_error_handler 捕获的错误中止脚本)
register_shutdown_function('handleShutdown') function handleShutdown() { if (! is_null($error = error_get_last()) && isFatal($error['type'])) { // handleException() 函数同时处理 set_exception_handler handleException(new \ErrorException( $error['message'], $error['type'], 0, $error['file'], $error['line'], )); } } function isFatal($type) { return in_array($type, [E_COMPILE_ERROR, E_CORE_ERROR, E_ERROR, E_PARSE]); }
<span style="font-size: 14px;"></span>
以下错误无法被 set_error_handler
捕获
E_ERROR
E_PARSE
E_CORE_ERROR
E_CORE_WARNING
E_COMPILE_ERROR
E_COMPILE_WARNING
若因为错误而结束脚本, 若是严重错误则可将其转为 异常类, 并由异常处理函数统一处理.
Note:
多次调用 register_shutdown_function
时不会互相覆盖, 而是会按照注册顺序被依次调用.
除非在某个注册的方法内部调用 exit()
Note:
进程被信号 SIGTERM
或 SIGKILL
杀死时中止函数不会被调用. 可通过 pcntl_signal
捕获信号, 再在其中调用 exit() 来进行正常中止。
以上就是关于错误异常的处理,如有错误请指出。不胜感激!
更多相关问题请访问PHP中文网:PHP视频教程
<span style="font-size: 14px;"></span>##
以上是關於PHP中異常錯誤的處理詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!