网上关于这个问题的解决方法有很多,这里就针对那些常用的方法做进一步的说明。
方法一:
error_reporting(E_ALL);
这种方法并不能捕获500错误,只能显示出“PHP Notice”、“PHP Warning”、“PHP Deprecated”之类的并不影响代码运行级别的错误,并且必须配合
ini_set(“display_errors”,”On”); 来使用,完整的用法应该是:
ini_set("display_errors","On"); error_reporting(E_ALL);
方法二:
ini_set("display_errors","On");
这种方法能捕获一部分500错误,比如“PHP Fatal error”之类的错误,这种错误可以称之为“严重错误”,一般由于程序中调用了一个没有定义的函数或是访问的文件路径不存在等等,会导致代码中断执行并出现500错误,用此方法即可显示出详细的错误信息并返回给页面正常的200状态。
方法三:
function cache_shutdown_error() { $_error = error_get_last(); if ($_error && in_array($_error['type'], array(1, 4, 16, 64, 256, 4096, E_ALL))) { echo '<font color=red>你的代码出错了:</font></br>'; echo '致命错误:' . $_error['message'] . '</br>'; echo '文件:' . $_error['file'] . '</br>'; echo '在第' . $_error['line'] . '行</br>'; } } register_shutdown_function("cache_shutdown_error");
这种方法看上去很“高大上”,但其实它的效果跟方法二是一样的,也只能捕获
“PHP Fatal error”之类的错误,碰到“PHP Parse error”这种最要命的语法错误也是没辙的,但我们在开发过程中难免一时疏忽少写或多写了个分号或是括号之类的,这种500错误是没有办法捕获到的,只能到web日志文件里面去查了!