PHP中error_reporting()用法详解
error_reporting()函数规定报告哪个错误。该函数设置当前脚本的错误报告级别。该函数返回旧的错误报告级别。
首先要知道error_reporting()函数是用来设置错误级别并返回当前级别的。它有14个错误级别,如下:
1E_ERROR致命的运行时错误。错误无法恢复过来。脚本的执行被暂停 2E_WARNING非致命的运行时错误。脚本的执行不会停止 4E_PARSE编译时解析错误。解析错误应该只由分析器生成 8E_NOTICE运行时间的通知。 16E_CORE_ERROR在PHP启动时的致命错误。这就好比一个在PHP核心的E_ERROR 32E_CORE_WARNING在PHP启动时的非致命的错误。这就好比一个在PHP核心E_WARNING警告 64E_COMPILE_ERROR致命的编译时错误。这就像由Zend脚本引擎生成了一个E_ERROR 128E_COMPILE_WARNING非致命的编译时错误,由Zend脚本引擎生成了一个E_WARNING警告 256E_USER_ERROR致命的用户生成的错误。 512E_USER_WARNING非致命的用户生成的警告。 1024E_USER_NOTICE用户生成的通知。 2048E_STRICT运行时间的通知。 4096E_RECOVERABLE_ERROR捕捉致命的错误。 8191E_ALL来所有的错误和警告。
好像php默认是不开启错误的,所以你需要配置php.ini文件:
将display_errors=Off改为display_errors=On
另外还要配置错误级别:将
error_reporting=E_ALL 改为:
error_reporting=E_ALL&~E_NOTICE
应为php默认是显示所有错误的,而有些无害的提示我们不需要显示,所以设置如上!
也可以在php代码运用如下:
<?php //禁用错误报告,也就是不显示错误 error_reporting(0); //报告运行时错误 error_reporting(E_ERROR|E_WARNING|E_PARSE); //报告所有错误 error_reporting(E_ALL); ?>
使用示例:
今天学习CI框架过程中遇到个问题:
APHPErrorwasencountered Severity:Notice Message:Undefinedvariable:user
一般在默认的普通PHP文件中输出一个未定义声明的变量是不会报错误的,但在codeigniter框架下却要报错误,这对于想集成添加和修改页面于一体的”懒人”很不方便,由于是初学者开始还想怎么在代码中屏蔽这一错误提示呢.甚至用到了@,但听很多人都说@会大大降低性能….
最后突然想到,是不是codeigniter有意让这错误信息提示出来了呢,我们该如何去屏蔽掉这一类错误呢无意中搜索到了”如何让codeigniter不显示Notice信息?”,茅塞顿开.原来是入口index.php中的error_reporting(E_ALL);在作怪.只需要把它改成
error_reporting(E_ALL^E_NOTICE);
就可以屏蔽掉这个错误,而不影响其他的报错.
我们在程序中可能经常看到这么一个函数
functionsetErrorReporting() { //从配置文件读取当前是否为开发环境 if(DEV_ENV==true){ ini_set("error_reprorting","E_ALL&~E_NOTICE"); ini_set("display_errors","on"); }else{ error_reporting(E_ALL); ini_set('display_errors','Off'); ini_set("log_errors","On"); ini_set('error_log','/var/log/phperror.log'); } }
举例说明:
在Windows环境下:原本在php4.3.0中运行正常的程序,在4.3.1中为何多处报错,大体提示为:Notice:Undefinedvarialbe:变量名称.
例如有如下的代码:
代码如下 复制代码
if(!$tmp_i){
$tmp_i=10;
}
在4.3.0中运行正常,在4.3.1中运行会提示Notice:Undefinedvarialbe:tmp_i
问题如下:1.问题出在哪里?
2.应如何修改这段代码?
3.不改段代码,如何修改php.ini中的设置使原来在4.3.0中的程序在4.3.1的环境下运行正常而不出现这个错误提示.
解决办法:
在程序开头加一句:
代码如下 复制代码
error_reporting(E_ALL&~E_NOTICE);或error_reporting(E_ALL^E_NOTICE);
或者修改php.ini:
代码如下 复制代码
error_reporting=E_ALL&~E_NOTICE
有关error_reporting()函数:error_reporting()设置PHP的报错级别并返回当前级别。
;错误报告是按位的。或者将数字加起来得到想要的错误报告等级。
;E_ALL-所有的错误和警告
;E_ERROR-致命性运行时错
;E_WARNING-运行时警告(非致命性错)
;E_PARSE-编译时解析错误
;E_NOTICE-运行时提醒(这些经常是是你的代码的bug引起的,也可能是有意的行为造成的。(如:基于未初始化的变量自动初始化为一个空字符串的事实而使用一个未初始化的变量)
;E_CORE_ERROR-发生于PHP启动时初始化过程中的致命错误
;E_CORE_WARNING-发生于PHP启动时初始化过程中的警告(非致命性错)
;E_COMPILE_ERROR-编译时致命性错
;E_COMPILE_WARNING-编译时警告(非致命性错)
;E_USER_ERROR-用户产生的出错消息
;E_USER_WARNING-用户产生的警告消息
;E_USER_NOTICE-用户产生的提醒消息
E_NOTICE表示一般情形不记录,只有程式有错误情形时才用到,例如企图存取一个不存在的变数,或是呼叫stat()函式检视不存在的档案。
E_WARNING通常都会显示出来,但不会中断程式的执行。这对除错很有效。例如:用有问题的常规表示法呼叫ereg()。
E_ERROR通常会显示出来,亦会中断程式执行。意即用这个遮罩无法追查到记忆体配置或其它的错误。
E_PARSE从语法中剖析错误。
E_CORE_ERROR类似E_ERROR,但不包括PHP核心造成的错误。
E_CORE_WARNING类似E_WARNING,但不包括PHP核心错误警告
使用方法:
error_reporting(0);//禁用错误报告
error_reporting(E_ALL^E_NOTICE);//显示除去E_NOTICE之外的所有错误信息
error_reporting(E_ALL^E_WARNING^E_NOTICE);//显示除去E_WARNINGE_NOTICE之外的所有错误信息
error_reporting(E_ERROR|E_WARNING|E_PARSE);//显示运行时错误,与error_reporting(E_ALL^E_NOTICE);效果相同。error_reporting(E_ALL);//显示所有错误
error_reporting(0)
error_reporting(255);
是列出所有提示
error_reporting(0);
是不显示所有提示
建议使用
error_reporting(7);
只显示严重错误
1E_ERROR致命的运行时错误
2E_WARNING运行时警告(非致命性错误)
4E_PARSE编译时解析错误
8E_NOTICE运行时提醒(经常是bug,也可能是有意的)
16E_CORE_ERRORPHP启动时初始化过程中的致命错误
32E_CORE_WARNINGPHP启动时初始化过程中的警告(非致命性错)
64E_COMPILE_ERROR编译时致命性错
128E_COMPILE_WARNING编译时警告(非致命性错)
256E_USER_ERROR用户自定义的致命错误
512E_USER_WARNING用户自定义的警告(非致命性错误)
1024E_USER_NOTICE用户自定义的提醒(经常是bug,也可能是有意的)
2048E_STRICT编码标准化警告(建议如何修改以向前兼容)
4096E_RECOVERABLE_ERROR接近致命的运行时错误,若未被捕获则视同E_ERROR
6143E_ALL除E_STRICT外的所有错误(PHP6中为8191,即包含所有)