PHP中error_reporting()函数的用法(修改PHP屏蔽错误)


Posted in PHP onJuly 01, 2011

今天学习CI框架过程中遇到个问题:

A PHP Error was encountered
Severity: Notice

Message: Undefined variable: user

一般在默认的普通PHP文件中输出一个未定义声明的变量是不会报错误的,但在codeigniter框架下却要报错误,这对于想集成 添加 和 修改 页面于一体的”懒人”很不方便,由于是初学者开始还想怎么在代码中屏蔽这一错误提示呢.甚至用到了@,但听很多人都说@会大大降低性能….

最后突然想到,是不是codeigniter有意让这错误信息提示出来了呢,我们该如何去屏蔽掉这一类错误呢无意中搜索到了”如何让codeigniter不显示Notice信息?”,茅塞顿开.原来是入口index.php中的error_reporting(E_ALL);在作怪.只需要把它改成

error_reporting(E_ALL ^ E_NOTICE);
就可以屏蔽掉这个错误,而不影响其他的报错.

下边是搜索到的一些资料:

error_reporting() 设置 PHP 的报错级别并返回当前级别。

语法
error_reporting(report_level)
如果参数 level 未指定,当前报错级别将被返回。下面几项是 level 可能的值:

1 E_ERROR
2 E_WARNING
4 E_PARSE
8 E_NOTICE
16 E_CORE_ERROR
32 E_CORE_WARNING
64 E_COMPILE_ERROR
128 E_COMPILE_WARNING
256 E_USER_ERROR
512 E_USER_WARNING
1024 E_USER_NOTICE
2047 E_ALL
2048 E_STRICT
E_NOTICE 表示一般情形不记录,只有程式有错误情形时才用到,例如企图存取一个不存在的变数,或是呼叫 stat() 函式检视不存在的档案。

E_WARNING 通常都会显示出来,但不会中断程式的执行。这对除错很有效。例如:用有问题的常规表示法呼叫 ereg()。

E_ERROR 通常会显示出来,亦会中断程式执行。意即用这个遮罩无法追查到记忆体配置或其它的错误。

E_PARSE 从语法中剖析错误。
E_CORE_ERROR 类似 E_ERROR,但不包括 PHP 核心造成的错误。
E_CORE_WARNING 类似 E_WARNING,但不包括 PHP 核心错误警告。

PHP 的错误报告

php.ini 文件中有许多配置设置。您应当已经设置好自己的 php.ini 文件并把它放在合适的目录中,就像在 Linux 上安装 PHP 和 Apache 2 的文档说明中所示的那样。在调试 PHP 应用程序时,应当知道两个配置变量。下面是这两个变量及其默认值:

display_errors = Off

error_reporting = E_ALL

通过在 php.ini 文件中搜索它们,可以发现这两个变量当前的默认值。display_errors 变量的目的很明显 —— 它告诉 PHP 是否显示错误。默认值是 Off。但是,要让开发过程更加轻松,请把这个值设为 On:

display_errors = On

error_reporting 变量的默认值是 E_ALL。这个设置会显示从不良编码实践到无害提示到出错的所有信息。E_ALL 对于开发过程来说有点太细,因为它在屏幕上为一些小事(例如变量未初始化)也显示提示,会搞糟浏览器的输出。我只想看到错误和不良编码实践,但是不想看到无害的提示。所以,请用以下值代替 error_reporting 的默认值:

error_reporting = E_ALL & ~E_NOTICE

重新启动 Apache,就全部设置好了。接下来,将学习如何在 Apache 上做同样的事。

服务器上的错误报告

依赖于 Apache 正在做的工作,在 PHP 中打开错误报告可能没法工作,因为在计算机上可能有多个 PHP 版本。有时很难区分 Apache 正在使用哪个 PHP 版本,因为 Apache 只能查看一个 php.ini 文件。不知道 Apache 正在使用哪个 php.ini 文件配置自己是一个安全问题。但是,有一种方法可以在 Apache 中配置 PHP 变量,从而保证设置了正确的出错级别。

而且,最好知道如何在服务器端设置这些配置变量,以否决或抢占 php.ini 文件,从而提供更高级别的安全性。
在配置 Apache 时,应该已经接触过 /conf/httpd.conf 中 http.conf 文件中的基本配置。

要做在php.ini文件中已经做过的事,请把下列各行添加到 httpd.conf,覆盖任何 php.ini 文件:

php_flag display_errors on

php_value error_reporting 2039

这会覆盖在 php.ini 文件中为 display_errors 已经设置的标志,以及 error_reporting 的值。值 2039 代表 E_ALL & ~E_NOTICE。如果愿意采用 E_ALL,请把值设为 2047。同样,还是要重启 Apache。

接下来,要在服务器上测试错误报告。

关于error_reporting()这个函数,它是可以屏蔽到一些错误信息,但是PHP 核心造成的错误,是无法屏蔽的,因为PHP 核心造成的错误会直接导致PHP文件编译失败,因为书写格式没有按照PHP的编码规则写而造成的错误,是无法屏蔽的

* For now, avoid warnings of E_STRICT mode 
* (this must be done before function definitions) 
*/ 
if (defined('E_STRICT')) { 
$old_error_reporting = error_reporting(0); 
if ($old_error_reporting & E_STRICT) { 
error_reporting($old_error_reporting ^ E_STRICT); 
} else { 
error_reporting($old_error_reporting); 
} 
unset($old_error_reporting);

常见的如下:
// Turn off all error reporting;关闭所有的错误 
error_reporting(0); // Report simple running errors;报告一个简单的运行错误 
error_reporting(E_ERROR | E_WARNING | E_PARSE); 
// Reporting E_NOTICE can be good too (to report uninitialized 
// variables or catch variable name misspellings …);包括报告一些未初始化的变量或捕捉变量名的拼写错误 
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE); 
// Report all errors except E_NOTICE 
// This is the default value set in php.ini;报告所有的错误但不包括E_NOTICE 这也是php.ini的缺省设置 
error_reporting(E_ALL ^ E_NOTICE); 
// Report all PHP errors (bitwise 63 may be used in PHP 3);报告所有的错误 
error_reporting(E_ALL); 
// Same as error_reporting(E_ALL);同上 
ini_set('error_reporting', E_ALL);
PHP 相关文章推荐
Zend studio for eclipse中使php可以调用mysql相关函数的设置方法
Oct 13 PHP
php不用内置函数对数组排序的两个算法代码
Feb 08 PHP
PHP 杂谈《重构-改善既有代码的设计》之五 简化函数调用
May 07 PHP
解析左右值无限分类的实现算法
Jun 20 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
Sep 10 PHP
PHP检测用户语言的方法
Jun 15 PHP
Laravel中注册Facades的步骤详解
Mar 16 PHP
今天你说520了吗?不仅有php表白书还有java表白神器
May 20 PHP
PHP 序列化和反序列化函数实例详解
Jul 18 PHP
PHP实现json_decode不转义中文的方法
May 20 PHP
form自动提交实例讲解
Jul 10 PHP
PHP 命名空间和自动加载原理与用法实例分析
Apr 29 PHP
PHP函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
Jul 01 #PHP
Can't create/write to file 'C:\WINDOWS\TEMP\...MYSQL报错解决方法
Jun 30 #PHP
在php中判断一个请求是ajax请求还是普通请求的方法
Jun 28 #PHP
php编程实现获取excel文档内容的代码实例
Jun 28 #PHP
PHP学习笔记之数组篇
Jun 28 #PHP
php设计模式 Visitor 访问者模式
Jun 28 #PHP
php懒人函数 自动添加数据
Jun 28 #PHP
You might like
php cc攻击代码与防范方法
2012/10/18 PHP
摘自织梦CMS中的图片处理类
2015/08/08 PHP
功能强大的php文件上传类
2016/08/29 PHP
Laravel框架实现利用中间件进行操作日志记录功能
2018/06/06 PHP
js操作select控件的几种方法
2010/06/02 Javascript
JavaScript 代码压缩工具小结
2012/02/27 Javascript
js面向对象 多种创建对象方法小结
2012/05/21 Javascript
JS测试显示屏分辨率以及屏幕尺寸的方法
2013/11/22 Javascript
jquery事件重复绑定的快速解决方法
2014/01/03 Javascript
不使用jquery实现js打字效果示例分享
2014/01/19 Javascript
js函数调用的方式
2014/05/06 Javascript
jQuery带箭头提示框tooltips插件集锦
2014/11/17 Javascript
jQuery中复合属性选择器用法实例
2014/12/31 Javascript
javascript实现 百度翻译 可折叠的分享按钮列表
2015/03/12 Javascript
JavaScript中Function函数与Object对象的关系
2015/12/17 Javascript
Bootstrap插件全集
2016/07/18 Javascript
JS+canvas动态绘制饼图的方法示例
2017/09/12 Javascript
vue中前进刷新、后退缓存用户浏览数据和浏览位置的实例讲解
2018/09/21 Javascript
微信小程序实现页面下拉刷新和上拉加载功能详解
2018/12/03 Javascript
使用jquery的cookie实现登录页记住用户名和密码的方法
2019/03/13 jQuery
JavaScript强制类型转换和隐式类型转换操作示例
2019/05/01 Javascript
js中比较两个对象是否相同的方法示例
2019/09/02 Javascript
Layui 解决表格异步调用后台分页的问题
2019/10/26 Javascript
nodejs制作小爬虫功能示例
2020/02/24 NodeJs
JavaScript eval()函数定义及使用方法详解
2020/07/07 Javascript
详解python使用Nginx和uWSGI来运行Python应用
2018/01/09 Python
python用quad、dblquad实现一维二维积分的实例详解
2019/11/20 Python
Python散点图与折线图绘制过程解析
2019/11/30 Python
Django实现whoosh搜索引擎使用jieba分词
2020/04/08 Python
Python logging日志库空间不足问题解决
2020/09/14 Python
施华洛世奇天猫官方旗舰店:SWAROVSKI
2017/04/17 全球购物
adidas爱尔兰官方网站:阿迪达斯运动鞋和运动服
2019/11/01 全球购物
LVMH旗下最大的奢侈品网站平台:24S
2020/05/24 全球购物
音乐系毕业生自荐信
2013/10/27 职场文书
我的老师教学反思
2014/05/01 职场文书
ztree+ajax实现文件树下载功能
2021/05/18 Javascript