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

php初级评论86字数 2595阅读8分39秒

10.1.错误分类

  • 语法错误:

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

  • 运行时错误:

语法检查没错,然后开始运行,在运行中出现了错误,然后报错。
这是开发中最常见的错误。文章源自国强极客生活-https://tagqwl.com/2677.html

  • 逻辑错误:

程序能运行,且一直到结束没有报错,但执行得到的结果却是错的。文章源自国强极客生活-https://tagqwl.com/2677.html

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

含义:
是指在程序运行时,发生的错误,系统会针对每种错误,给出相应的错误代号,并进行提示(报错)。
另外,程序如果在运行之前检查语法的时候就发现语法错误,也会报错,也有一个错误代号。文章源自国强极客生活-https://tagqwl.com/2677.html

常见错误代号有:文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_NOTICE:

提示性错误,轻微;
错误发生后,后面的程序继续执行。文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_WARNING:

警告性错误,稍微严重;
错误发生后,后面的程序继续执行。文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_ERROR:

严重错误/致命错误;
错误发生后,后面的程序不再执行!文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_PARSE:

语法错误(语法解析错误);
语法解释错误,是直接就不运行程序。文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_USER_NOTICE:

用户自定义的提示错误文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_USER_WARNING:

用户自定义的警告错误文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_USER_ERROR:

用户自定义的严重错误文章源自国强极客生活-https://tagqwl.com/2677.html

  • E_ALL:

它是一个代表“所有”错误的代号。文章源自国强极客生活-https://tagqwl.com/2677.html

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

10.3.错误触发

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

自定义错误触发语法:
trigger_error(“自定义错误提示内容”, 自定义错误的代号);文章源自国强极客生活-https://tagqwl.com/2677.html

案例演示:

输入一个年龄(简化为变量值),如果年龄超过60或小于0,就触发一个notice错误!文章源自国强极客生活-https://tagqwl.com/2677.html

10.4.错误显示设置

如果有错误发生(触发了错误),默认情况下会被显示在页面(即输出的结果页面)。文章源自国强极客生活-https://tagqwl.com/2677.html

我们可以对此进行设置,以决定以下两点:文章源自国强极客生活-https://tagqwl.com/2677.html

  • 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 | .....)

代码演示:文章源自国强极客生活-https://tagqwl.com/2677.html

10.5.错误日志设置

如果有错误发生(触发了错误),默认情况下不会将错误信息记录(保存)下来。文章源自国强极客生活-https://tagqwl.com/2677.html

我们可以对此进行设置,以决定以下两点:
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>";
weinxin
我的微信
添加我的微信,有任何问题请与我直接联系(备注:国强极客生活)
  • 全部本人精心整理制作,希望大家多多支持。
  • 转载请务必保留本文链接:https://tagqwl.com/2677.html
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: