php捕获致命错误
记录php错误日志可以有力的帮我们查找问题、修复bug,php提供了set_error_handler
、set_exception_handler
来捕获错误和异常。但是set_error_handler
并不能捕获E_ERROR
、 E_PARSE
、 E_CORE_ERROR
、E_CORE_WARNING
、E_COMPILE_ERROR
、E_COMPILE_WARNING
、E_STRICT
等错误。一般来讲,如果是致命错误,会导致php解释器都无法编译通过,自然不能捕获这些错误,但是,我们可以通过一些方法来巧妙的得到这些错误信息。首先先建立一个tmp.php
<?php
//error_reporting(0);
ob_start();
set_error_handler('errorHandler');
register_shutdown_function( 'close' );
function 大专栏 php捕获致命错误class="hljs-title">close(){
ob_end_clean();
$error = error_get_last();
echo '<pre>';
print_r($error);
}
require 'short.php';
然后在short.php中写入一些错误代码,如
echo $a//故意不加分号
然后访问tmp.php,就会发现,页面没有显示php自身的错误提示,而是执行了close方法。以上代码关键几点。
- 第一、开启
ob_start
- 第二:使用
register_shutdown_function
注册函数 - 第三:使用
error_get_last
函数获取错误信息 - 第四:php解析的第一个文件不能出现致命错误,否则无法捕获。所以也推荐大家搭建自己的框架或者选择框架时,最好使用单一入口方式