PHP与MySQL程序设计 学习笔记 第八章 错误和异常处理

本文主要是介绍PHP与MySQL程序设计 学习笔记 第八章 错误和异常处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

error_reporting函数确定报告的敏感级别,共有16个不同级别,这些级别的任何组合都是有效的:
在这里插入图片描述
error_reporting函数使用~字符表示逻辑操作符NOT。

error_reporting(E_ALL & E_STRICT);    // 希望报告所有错误,php 5.4.0前E_ALL并不包含E_STRICT
error_reporting(E_ERROR | E_PARSE | E_CORE_ERROR);    // 只考虑运行时错误、编译解析错误、核心错误
error_reporting(E_ALL & ~E_USER_WARNING);    // 报告除E_USER_WARNING之外的所有错误
error_reporting(E_ALL ^ E_USER_WARNING);    // 同上
ini_set('error_reporting', E_ALL ^ E_USER_WARNING);    // 同上

返回当前的错误报告设置:

var_dump(error_reporting());    // 可将此函数结果与具体的常量相与查看是否开启了该常量对应的错误报告

启用display_errors指令时,将显示满足error_reporting所定义规则的所有错误。启用该指令:

ini_set('display_errors', true);

此设置应在测试时使用,投入网站时会将错误信息打印在网页上,可能会泄露服务器的信息。

php 5.2中引入了函数error_get_lsat,它会返回一个关联数组,包含最后出现的错误类型、消息、文件和行号:

error_reporting(E_ALL);
ini_set('display_errors', false);class a {public function func() {print("in func");}
}a::func();print_r(error_get_last());

运行它:
在这里插入图片描述
显示php引擎初始化时遇到的所有错误,此指令也只应在测试时启用:

ini_set('display_startup_errors', true);

启用log_errors指令可将日志记录下来:

ini_set('error_reporting', E_NOTICE);    // 记录notice级别日志
ini_set('log_errors', true);    // 启用日志记录
ini_set('error_log', '日志路径');    // 设置日志路径$arr = [];
$arr[1];

运行它什么也没有输出,接着查看日志:
在这里插入图片描述
如果日志文件指令error_log设置为系统日志后台程序,则在linux上错误将被送往syslog,windows上会被送往事件日志(相当于linux上的syslog)。这些系统日志提供了接口来记录系统和应用执行有关的消息。

设置日志行的最大长度(以字节为单位),默认1024字节,设为0表示不指定最大长度:

ini_set('log_errors_max_len', 1);

如果设为1,实际效果为:
在这里插入图片描述
只显示了U,实际完整的日志内容为:
在这里插入图片描述
忽略同一文件中同一行上发生的重复错误消息:

ini_set('ignore_repreated_errors', true);

忽略不同文件中或同一文件中不同行上重复的错误信息:

ini_set('ignore_repreated_source', '1');

将上次出现的错误消息存放到变量php_errormsg中:

ini_set('log_errors', true);
ini_set('error_log', 'C:\Users\X\Desktop\phpLog.txt');
ini_set('log_errors_max_len', 1);
ini_set('track_errors', '1');    // 如果此指令开启,则将上次出现的错误信息存在变量php_errormsg中$arr = [];
$arr[1];print("in var: " . $php_errormsg);

运行它:
在这里插入图片描述
如果在共享服务器上,错误日志可能只能记录在单独的文本文件或数据库表中;如果在独占服务器上,则可将错误日志记录在syslog中,这样可使用syslog提供的解析工具查看和分析日志。

如果使用syslog,可使用以下函数向syslog发送定制的消息:
1.初始化php的日志工具的函数,会初始化一些常量,这些常量是使用后面函数时必需的:
在这里插入图片描述
如果运行PHP 5.2或更早版本,运行下面日志函数时前需要先执行此函数。这个函数在php 6.3中被废弃,因为PHP 5.2之后的版本中调用openlog和syslog时会自动初始化。
2.打开与所在平台上系统日志器的连接,该函数是可选的,只有希望在日志消息前加一个预定义字符串时才有必要调用,否则可直接调用syslog:
在这里插入图片描述
参数:
(1)ident:每项消息开始处的消息标识符,通常设为程序名。
(2)option:见下表,多个选项间可用|连接:
在这里插入图片描述
(3)facility:可取值有LOG_KERN、LOG_USER、LOG_MAIL、LOG_DAEMON、LOG_AUTH、LOG_LPR、LOG_CORN、LOG_LOCALN(N为0~7的值),这些值确定了消息的目标,比如php可能通过crontab执行,可将该选项设为LOG_CORN,使后续的消息被发送到cron日志。一般此参数设为LOG_USER,消息会被发送到messages文件。
3.关闭由openlog函数打开的连接:
在这里插入图片描述
4.向日志发送消息:
在这里插入图片描述
第一个参数表示优先级,可以是以下值:
在这里插入图片描述
第二个参数为要记录的文本消息,如果希望记录由php引擎提供的错误消息,可在message中包含%m,它会被php引擎运行时提供的错误消息字符串strerror所代替。

使用以上函数:
在这里插入图片描述
会在messages syslog文件中生成以下日志:
在这里插入图片描述

php中类名、方法名是不区分大小写的:

class a {public function func() {print(1);}
}$aObj = new A();
print($aObj->Func());

运行它:
在这里插入图片描述
基本异常类Exception包括一个默认构造函数:
在这里插入图片描述
还有一个接受三个可选参数的构造函数:
在这里插入图片描述
参数按从左到右位置顺序:
(1)message:作为对异常的解释。
(2)error code:用于保存错误标识符,可用于映射到某自定义标识符–消息表,通常用于国际化和本地化。
(3)previous:php 5.3.0新增,可用来传入导致抛出当前异常的异常,该特性称为异常串链,也称为异常嵌套。

异常类有以下方法:
1.getCode():返回传给构造函数的错误代码。
2.getFile():返回抛出异常的文件名。
3.getLine():返回抛出异常的行号。
4.getMessage():返回传递给构造函数的消息。
5.getPrevious():php 5.3.0中新增,返回前一个异常。
6.getTrace():返回一个数组,包含错误的上下文消息,包括文件名、行号、函数名、函数参数。
7.getTraceAsString():返回字符串版的6。

虽然可扩展异常类,但不能覆盖基类Exception中的任何方法,它们都是final的。

使用异常类:

try {$fh = fopen("afile", "r");if (!$fh) {throw new Exception("can't open file");    // new是必需的}
} catch(Exception $e) {print("Error (File: " . $e->getFile() . ", line " . $e->getLine() . "): " . $e->getMessage());
}

运行它:
在这里插入图片描述
扩展异常类:

class MyException extends Exception {public function __construct($msg) {parent::__construct($msg);print("in my exception class\n");}
}try {throw new MyException("can't open file");
} catch(Exception $e) {print("Error (File: " . $e->getFile() . ", line " . $e->getLine() . "): " . $e->getMessage());
} catch(MyException $e) {print("MyException caught");
}

运行它:
在这里插入图片描述
而如果把上例中的两个catch语句调换位置:

<?php
class MyException extends Exception {public function __construct($msg) {parent::__construct($msg);print("in my exception class\n");}
}try {throw new MyException("can't open file");
} catch(MyException $e) {print("MyException caught");
} catch(Exception $e) {print("Error (File: " . $e->getFile() . ", line " . $e->getLine() . "): " . $e->getMessage());
}

运行它:
在这里插入图片描述
这说明如果抛出的是A类的派生类B的异常对象,则catch语句中A类和B类都能捕获B类异常对象,哪个catch语句就进入哪个catch块。

SPL(Standard PHP Library,php标准库)扩展了php,其中预定义了13个异常:
1.BadFunctionCallException:如果调用了未定义的函数或调用函数时参数的个数不对可使用该类。
2.BadMethodCallException:如果调用了未定义的方法或调用方法时参数的个数不对可使用该类。
3.DomainException:当某个输入值超出范围时,可抛出该异常。
4.InvalidArgumentException:如果传入一个函数或方法的参数类型不兼容,可抛出该异常。
5.LengthException:当一个字符串的长度不合法时,可抛出该异常。
6.LogicException:是SPL异常扩展的两个基类之一,处理程序编写不正确的情况。
7.OutOfBoundsException:当提供的键与数组中所有键都不匹配时可使用。
8.OutOfRangeException:当一个函数的输出值超出一个预定义范围时,可抛出该异常。
9.OverflowException:当算数溢出或缓冲区上溢出时,可抛出该异常。
10.RangeException:DomainException的运行时版本。
11.RuntimeException:是SPL异常扩展的两个基类之一,处理只在运行时出现的问题。
12.UnderflowException:当算数溢出或缓冲区下溢出时,可抛出该异常。
13.UnexpectedValueException:当提供的值与预定义的值集不匹配时,可抛出该异常。

try {throw new RangeException("I'm RangeException");
} catch(Exception $e) {print("in Exception catch\n");print($e->getMessage());
} catch(RuntimeException $e) {print("in RuntimeException catch\n");print($e->getMessage());
} catch(RangeException $e) {print("in RangeException catch\n");print($e->getMessage());
}

运行它:
在这里插入图片描述
由此,SPL中扩展的异常类是基于Exception的。

而当去掉Exception的catch时,输出会变成:
在这里插入图片描述
RuntimeException是基于Exception的,而RangeException是基于RuntimeException的。

这篇关于PHP与MySQL程序设计 学习笔记 第八章 错误和异常处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/940688

相关文章

Linux-笔记 i2c-tools

1、i2c-tools介绍 1、在日常linux开发中,有时候需要确认i2c硬件是否正常连接,设备是否正常工作,设备的地址是多少等等,这里我们就需要使用一个用于测试I2C总线的工具——i2c-tools,i2c-tools原理是通过操作/dev 路径 i2c-n设备文件完成,因此kernel必须开启了 CONFIG_I2C_CHARDEV 配置,否者会报找不到节点。在设备上也可以通过目标板终端输

GPIO基础知识学习

前言: 本文记录了我自己学习最基本的单片机电路知识的学习笔记。本文参考了引用链接中的大量内容,并加上了自己的很少的一点思考(因为我本人的电路知识基本没有)。 引用: 上拉电阻与下拉电阻总结 与 GPIO框图分析_上拉 下拉 高阻-CSDN博客 推挽、开漏、强上拉、弱上拉、强下拉、弱下拉输出-CSDN博客 正文: 因为之前完全没有基本的电路知识和概念,所以这里记录的都是一些参考引用

web API设计笔记

Hello , 我是小恒。今晚就讲讲我在开发维护API后的经验分享,当然我知识有限,暂时也不会写实际操作。GitHub项目仓库有一堆还在前期开发,我的时间很多时间投在了开源上。 推荐书籍 我认为一个好的 API 设计是面向用户的,充分隐藏底层复杂原理。我们就要设计出让用户容易理解和容易使用的 API。 开发 设计 API 规范有两个方向Design-First(设计优先) 和 Co

英语学习笔记6——What make is it?

What make is it? 它是什么牌子的? make n.(产品的)品牌名称    v. 制作 区别:model n.(产品的)型号       n. 模型       n. 模特 make 指的是大的品牌名称, model 是旗下产品 比如:make —— Audi(奥迪)    model —— A6 Swedish adj. 瑞典的 n. 瑞典人,瑞典语 Sweden n. 瑞典

[机器学习系列]深入探索回归决策树:从参数选择到模型可视化

目录 一、回归决策树的参数 二、准备数据  三、构建回归决策树 (一)拟合模型 (二)预测数据 (三)查看特征重要性  (四)查看模型拟合效果 (五) 可视化回归决策树真实值和预测值 (六)可视化决策树并保存  部分结果如下: 一、回归决策树的参数 DecisionTreeRegressor(*, criterion='mse', splitter='best',

Python:文件与异常(五)

文章目录 1. 异常1.1 处理异常1.2 异常传播与抛出(自定义异常) 2.文件2.1 打开与关闭2.2 文件读取2.3 文件写入 1. 异常 1.1 处理异常 程序运行时出现异常,目的并不是让我们的程序直接终止!Python是希望在出现异常时,我们可以编写代码来对异常进行处理! try语句try:代码块(可能出现错误的语句)except 异常类型 as 异常名:

一起深度学习——CIFAR10

CIFAR10 目的:实现步骤:1、导包:2、下载数据集3、整理数据集4、将验证集从原始的训练集中拆分出来5、数据增强6、加载数据集7、定义训练模型:8、定义训练函数:9、定义参数,开始训练: 目的: 实现从数据集中进行分类,一共有10个类别。 实现步骤: 1、导包: import collectionsimport torchfrom torch import nn

Java笔记(其八)--- 方法(函数)

方法         方法,其实就是C语言中的函数,在写作形式上仅有一点点的区别。          修饰词 返回值类型 函数名(形参){ ... }         例如 package com.su_de_lei;/*** 写一个两数相加的函数*/public class FunctionCode {public static void main(String[] args)

政安晨:【Keras机器学习示例演绎】(三十九)—— 使用 FNet 进行文本分类

目录 简介 模型 设置 加载数据集 对数据进行标记 格式化数据集 建立模型 训练我们的模型 与变换器模型比较 政安晨的个人主页:政安晨 欢迎 👍点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras机器学习实战 希望政安晨的博客能够对您有所裨益,如有不足之处,欢迎在评论区提出指正! 本文目标:使用 keras_nlp.layers.FNetEncode

Vue2.0学习记录

Vue教程 文章目录 Vue教程1.介绍1.1简介1.2 vue插件制作1.3 helloword1.4 mvvm理解1.5 声明周期 2.使用2.1 vue常用属性2.1.1 el挂载点2.1.2 data属性 2.2 vue指令2.2.1 v-text2.2.2 v-html2.2.3 v-on2.2.3.1 事件修饰符2.2.3.2 按键修饰符 2.2.4 v-show2.2.5 v