PHP自动捕捉页面500错误
来源:互联网 发布:唯品会淘宝天猫哪个好 编辑:程序博客网 时间:2024/06/04 01:02
通常程序发生致命错误的时候页面空白,想获取错误信息也不难!主要是利用两个函数:
error_get_last() 获取最后一次发生错误信息:结构如下:
Array( [type] => 8 [message] => Undefined variable: http://www.111cn.net [file] => C:WWWindex.php [line] => 2)
register_shutdown_function()在脚本停止执行时注册一个回调函数
有了这两个函数就可以监控致命错误了:
error_reporting(E_ALL); //E_ALLfunction 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配置中与此相关的有两个配置变量。下面是这两个变量及其默认值:
display_errors = Offerror_reporting = E_ALL & ~E_NOTICE
display_errors 变量的目的很明显 —— 它告诉PHP是否显示错误。默认值是 Off。现在我们的目的是显示错误提示,那么:
display_errors = On
E_ALL,这个设置会显示从不良编码实践到无害提示到出错的所有信息。E_ALL 对于开发过程来说有点太细,因为它连变量未初始化也显示提示,而这一点正是PHP“高级”的一个特征。幸好,error_reporting的默认值是“E_ALL & ~E_NOTICE”,这样就只看到错误和不良编码了,对程序无不利的提示则不会显示。
修改php.ini后需要重新启动Apache,这样才可以在apache中生效,当然你如果只在命令行下测试程序,是不需要这一步的。
配置php程序中
<?php //禁用错误报告 error_reporting(0); //报告运行时错误 error_reporting(E_ERROR | E_WARNING | E_PARSE); //报告所有错误 error_reporting(E_ALL); ?>
阅读全文
0 0
- PHP自动捕捉页面500错误
- PHP自动捕捉页面500错误
- 页面错误详细信息的捕捉
- php错误及异常捕捉
- php错误及异常捕捉
- php错误及异常捕捉
- PHP 捕捉错误,记录到日志
- PHP捕捉普通异常和致命错误
- 常见jsp出现的页面错误(404,500等)与捕捉办法
- 常见jsp出现的页面错误(404,500等)与捕捉办法
- php 在页面中调试错误(解决php错误500)
- 错误捕捉
- [python&php 网络编程]socket的错误捕捉
- php自动跳转中英文页面
- php自动跳转中英文页面
- 页面捕捉的问题
- php页面上错误显示
- ad9 自动捕捉功能
- 不同版本的python共用一个opencv
- mac 终端 使用ftp命令
- spring-boot文章收集
- SpringMVC配置
- net-snmp开发过程整理-src开发
- PHP自动捕捉页面500错误
- 调试CRF出现的错误:cannot be interpreted as a Tensor.
- Mybatis之序列插入语句(Mysql和Oracle)
- kuangbin专题五并查集 POJ1308 Is It A Tree?(并查集)
- 网络编程代码实例
- 图像处理笔试面试题
- 开发jQuery插件
- mybatis详解-(10)别名
- Java权限管理系统