一般程序发生致命错误的时候页面空白,想获取错误信息也不难!主要是利用两个函数:php
error_get_last() 获取最后一次发生错误信息:结构以下:python
Array ( [type] => 8 [message] => Undefined variable: http://www.111cn.net [file] => C:WWWindex.php [line] => 2 )
register_shutdown_function()在脚本中止执行时注册一个回调函数apache
有了这两个函数就能够监控致命错误了:服务器
error_reporting(E_ALL); //E_ALL 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错误提示消息的三个方法。测试
一:php.ini配置编码
php.ini配置中与此相关的有两个配置变量。下面是这两个变量及其默认值:.net
display_errors = Off error_reporting = E_ALL & ~E_NOTICE
display_errors = On
E_ALL,这个设置会显示从不良编码实践到无害提示到出错的全部信息。E_ALL 对于开发过程来讲有点太细,由于它连变量未初始化也显示提示,而这一点正是PHP“高级”的一个特征。幸亏,error_reporting的默认值是“E_ALL & ~E_NOTICE”,这样就只看到错误和不良编码了,对程序无不利的提示则不会显示。 命令行
修改php.ini后须要从新启动Apache,这样才能够在apache中生效,固然你若是只在命令行下测试程序,是不须要这一步的。code
配置php程序中
<?php //禁用错误报告 error_reporting(0); //报告运行时错误 error_reporting(E_ERROR | E_WARNING | E_PARSE); //报告全部错误 error_reporting(E_ALL); ?>