国强极客
有问题请加微信:guoqiang7585
国强极客

10、php错误处理 错误触发 错误分类 错误日志

10、php错误处理 错误触发 错误分类 错误日志

10.1.错误分类

  • 语法错误:

程序不能运行,是在运行之前,检查语法的时候,就发现语法出错,结果是提示错误,不运行程序。

  • 运行时错误:

语法检查没错,然后开始运行,在运行中出现了错误,然后报错。
这是开发中最常见的错误。

  • 逻辑错误:

程序能运行,且一直到结束没有报错,但执行得到的结果却是错的。

10.2.常见错误代号(重点)

含义:
是指在程序运行时,发生的错误,系统会针对每种错误,给出相应的错误代号,并进行提示(报错)。
另外,程序如果在运行之前检查语法的时候就发现语法错误,也会报错,也有一个错误代号。

常见错误代号有:

  • E_NOTICE:

提示性错误,轻微;
错误发生后,后面的程序继续执行。

  • E_WARNING:

警告性错误,稍微严重;
错误发生后,后面的程序继续执行。

  • E_ERROR:

严重错误/致命错误;
错误发生后,后面的程序不再执行!

  • E_PARSE:

语法错误(语法解析错误);
语法解释错误,是直接就不运行程序。

  • E_USER_NOTICE:

用户自定义的提示错误

  • E_USER_WARNING:

用户自定义的警告错误

  • E_USER_ERROR:

用户自定义的严重错误

  • E_ALL:

它是一个代表“所有”错误的代号。

说明:
1,这些错误代号,其实只是系统预先设定的一些常量,他们的值大约是:1, 2, 4, 8, 16…..
2,这些错误代号,通常只是用于对错误控制时进行“设置”使用。
3,他们是一系列的整数,并具有一定的规律:1,2,4,8,16,32,64, 。。。。
4,可以在php.ini中使用(设置)他们,如下所示:

10.3.错误触发

就是发生了一个错误的意思——即触发了错误。
有两种情形会触发错误:
1,程序本身有错,则运行时就会触发错误(并提示)。
2,程序本身没错,但出现不符合预计的情形(比如数据不符合要求)。
此时程序员可以主动触发一个错误,也可以说是由程序员“主动创建一个错误”
——这就是“用户错误”,包括:
E_USER_NOTICE:
E_USER_WARNING:
E_USER_ERROR:
如何触发“用户错误”呢?

自定义错误触发语法:
trigger_error(“自定义错误提示内容”, 自定义错误的代号);

案例演示:

输入一个年龄(简化为变量值),如果年龄超过60或小于0,就触发一个notice错误!

10.4.错误显示设置

如果有错误发生(触发了错误),默认情况下会被显示在页面(即输出的结果页面)。

我们可以对此进行设置,以决定以下两点:

  • 1,设置display_errors以决定是否显示错误:
    在php.ini中设置: display_errors = On或Off
    这里设置,影响所有使用该php语言引擎的代码(网站页面);
    在php文件中设置: ini_set(‘display_errors’, 1或0); //1表示显示,0不显示
    在这里设置,只影响当前网页代码本身。
  • 2,设置error_reporting以决定显示哪些错误:
    在php.ini中设置: error_reporting = 错误代号1 | 错误代号2 | …..
    //(要显示的就写出来,或者可以写E_ALL, 表示显示所有)
    在代php文件中,道理类似:ini_set(‘error_reporting’, 错误代号1 | 错误代号2 | …..)

代码演示:

10.5.错误日志设置

如果有错误发生(触发了错误),默认情况下不会将错误信息记录(保存)下来。

我们可以对此进行设置,以决定以下两点:
1,设置log_errors以决定是否记录错误:
php.ini中设置: log_errors = On 或 Off
代码文件中设置:

ini_set (‘log_errors’, 1或0)

2,设置error_log以决定记录到哪里:
通常,就设置为一个文件名,php系统会在网站的每个文件夹下都建立该文件,并记录错误。
php.ini中: error_log = error.txt; //它是纯文本的
代码中:

ini_set(“error_log”,  ‘error.txt’);

error_log.txt中的内容类似如下:

10.6.自定义错误处理(重点/难点)

之前,我们面对的情形都是错误发生的时候,系统生成错误,并处理错误(给出错误信息)。
我们能控制的就只是:是否显示,显示什么,是否记录,记录到哪里?

实际上,我们也可以更进一步控制错误信息,以决定错误发生的时候,显示什么样的错误信息。
这就是“自定义错误处理”。

具体做法,分2步:
第1步:
声明错误发生时,由我们自己来处理——设定一个错误处理的函数名。
第2步:
定义该函数,在函数中详细设定错误的处理情况:怎么显示,显示什么,怎么记录,记录什么。
演示案例:

//自定义错误,分2步:
//1,声明,我们自己使用自己的函数来处理错误
//set_error_handler("处理错误的自己的函数名");
set_error_handler("my_error_handler");
//2,定义该函数!
function my_error_handler($errCode, $errMsg, $errFile, $errLine)
//参数解释:errCode错误代号,errMsg错误信息,errfile错误文件,errline行号
//此形参顺序固定,而且是由系统会调用该函数并传入实参数据!
{
    //此函数中,我们就可以去自己显示有关错误信息,和记录信息
    $str = "<p>大事不好了,发生错误了,快来人啊。。。";
    $str .= "<br>发生时间:" . date('Y-m-d H:i:s');
    $str .= "<br>错误代号:" . $errCode;
    $str .= "<br>错误信息:" . $errMsg;
    $str .= "<br>错误文件:" . $errFile;
    $str .= "<br>错误行号:" . $errLine;
    $str .= "</p>";
    echo $str;
    //也可以在这里继续去“记录错误”——就是错误日志
    //FILE_APPEND表示该函数使用“追加模式”来写入数据
    file_put_contents("./error.html", $str, FILE_APPEND);
}

//先给出几个出错的代码:
echo "<br>v1=$v1";  //未定义的变量

include './no-this-file.php';   //载入失败

function I1(){}
l1();       //调用不存在的函数;

echo "<p>最后的段落</p>";
赞赏
对内容有疑问,请加我微信:guoqiang7585
# # #
首页      全栈教程      php初级      10、php错误处理 错误触发 错误分类 错误日志

国强极客

文章作者

博客站长,有问题请加微信【guoqiang7585】。

国强极客

10、php错误处理 错误触发 错误分类 错误日志
10.1.错误分类 语法错误: 程序不能运行,是在运行之前,检查语法的时候,就发现语法出错,结果是提示错误,不运行程序。 运行时错误: 语法检查没错,然后开始运行,在运行中出…
扫描二维码继续阅读
2019-12-06