错误的分类
- 1.语法错误
- 2.运行时错误:只有程序运行到某行,或在某些特定的情况下运行才发生的错误。
- 3.逻辑错误。
错误的分级
在php中,将各种错误分门别类,依据不同的严重程度和产生的来源(机制),将各种错误分为大约十几个级别。每个级别的错误都对应一个内部的名称--系统常量。
1.系统错误
-
E_ERROR
:系统严重错误,已发生程序立即停止执行。马上需要解决 -
E_WARNING
:系统警告,希望在下一版本中修改。 -
E_NOTICE
:系统提示 -
E_PARSE
:语法错误,预编译时出现 - 它们的本质:他们其实是系统内的内部常量,准确的说是整数常量。实际上,这些常量是供我们对该类错误进行“控制”的标识符而已。
2.用户自定义错误
我们可以在程序中,自己创建(生成)错误,主要是为了针对某些数据的不合理情形,做出人性化的提示
-
E_USER_ERROR
:用户严重错误,不会向下编译 -
E_USER_WARNING
:用户警告性错误 -
E_USER_NOTICE
:用户提示性错误
其他
-
E_ALL
:代表所有错误,表示它可以"包括"错误。 -
E_STRICT
:启用PHP对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。跟上时代的友情提醒。
人工触发错误
trigger_error("用户严重错误,不会向下编译",E_USER_ERROR);
trigger_error("用户警告性错误",E_USER_WARNING);
trigger_error("用户提示性错误",E_USER_NOTICE);
错误提示形式
1.显示错误:
1.屏蔽错误信息:ini_set('display_errors',false);开发环境关闭,生产环境可以打开。
2.在php.ini文件中设定,对php程序都有效。display_error=on表示显示off表示不显示
3.设定显示那些级别的错误,依赖于错误是否在页面中显示.
error_reporting=E_NOTICE //只显示E_NOTICE错误
error_reporting=E_NOTICE | E_WARNING //只显示E_NOTICE、E_WARNING这两个错误,以前的版本E_ALL | E_STRICT表示所有错误,现在的版本E_ALL表示所有错误。
4.脚本设定优先级高于php.ini的设定
ini_set("设定名称",值)//这种设定只对当前脚本有效,而且无需重启apache
ini_get("设定名称")//用于获取某项的值
2.保存到日志
开发阶段,我们通常都是显示所有错误,目的是为了快速定位错误。但在产品上线后,我们通常都是隐藏所有的错误,同时将错误信息记录到文件中,即保存到错误日志文件中。
记录错误日志有两种途径:
- 在php.ini文件中设定
log_errors = ON;//用于设定是否记录错误日志
error_log=php_errors.log//设定错误日志文件名
//error_log有一个特殊值可以使用:
//error_log=syslog,此时不会记录错误日志,而是把错误记录到操作系统错误中
//error_log=E_ALL | E_STRICT &~E_NOTICE;//之关闭了
此时,该文件没有指定路径,系统会在每个文件夹下生成一个这样的日志文件
- 在当前脚本中
ini_set("log_errors",on);
ini_set("error_log",'err1.log');
自定义错误处理
以上的错误处理,不管是显示错误,还是记录错误日志,都是php语言内部实现的,我们只是设置是否显示、是否记录、是否显示那些或记录到哪里。
自定义错误,就是让我们完全控制错误的提示内容。
做法:
//1.设定错误有我们自定义函数来处理:set_error_handler("函数名")
set_error_handler("myError");
//2.定义该函数,带4个参数,function errorHandler($errNO,$errMsg,$errFile,$errLine)
/**
$errNO:错误级别
$errMsg:错误提示信息
$errFile:错误所在文件名
$errLine:错误所在行
**/
function myError($errNO,$errMsg,$errFile,$errLine){
echo "文件($errFile)的第($errLine)行发生错误";
echo "错误号($errNO),错误提示信息:$errMsg";
}
``
#####几点说明:
1. 用自定义错误处理程序,则系统不再处理错误
2. 如果一旦发生严重错误(E_ERROR,E_USER_ERROR),则立即停止程序,并调用系统错误处理