Gitlib Gitlib
首页
  • 分类
  • 标签
  • 归档
  • Golang开发实践万字总结
  • MySQL核心知识汇总
  • Redis实践总结
  • MQ实践万字总结
  • Docker数据持久化总结
  • Docker网络模式深度解读
  • 常用游戏反外挂技术总结
  • 读书笔记
  • 心情杂货
  • 行业杂谈
  • 友情链接
关于我
GitHub (opens new window)

Ravior

以梦为马,莫负韶华
首页
  • 分类
  • 标签
  • 归档
  • Golang开发实践万字总结
  • MySQL核心知识汇总
  • Redis实践总结
  • MQ实践万字总结
  • Docker数据持久化总结
  • Docker网络模式深度解读
  • 常用游戏反外挂技术总结
  • 读书笔记
  • 心情杂货
  • 行业杂谈
  • 友情链接
关于我
GitHub (opens new window)
  • PHP

    • PHP-FPM使用指南
    • PHP7新特性总结
    • PHP安全编程
    • PHP安全配置总结
    • PHP变量的值类型和引用类型
    • PHP标准规范PSR
    • PHP操作Zookeeper实践
    • PHP错误和异常处理机制详解
      • 错误处理
        • 简单的die()语句
        • 自定义错误处理器
        • 错误报告级别
        • 错误触发器
        • 错误日志
      • 异常处理
        • 基本语法
    • PHP的Session运行机制
    • PHP底层运行机制和原理
    • PHP反射模拟实现注解路由
    • PHP高级用法总结
    • PHP开发常用文档总结
    • PHP开发入门:Memcached扩展安装
    • PHP开发入门:PHP7安装部署
    • PHP开发入门:Redis扩展安装
    • PHP开发SPL总结
    • PHP框架常见URL模式
    • PHP扩展开发入门
    • PHP垃圾回收机制
    • PHP类的自动加载
    • PHP输入输出流
    • PHP微服务开发指南
    • PHP协程
    • PHP写时拷贝技术
    • PHP性能优化之Opcache
    • PHP依赖注入和控制反转
    • PHP运行模式(SAPI)
    • PHP中file_get_contents与curl区别
    • RPC的简单实现
    • Protobuf:高效数据结构化工具
    • P3P协议详解
    • Laravel之集合(Collection)总结
    • Laravel实践总结
    • Laravel之ORM总结
    • 中高级PHP实践总结
    • PHP Socket编程实战
  • Golang

  • Python

  • Javascript

  • 其他语言

  • 编程语言
  • PHP
Ravior
2018-07-03
目录

PHP错误和异常处理机制详解

# 错误处理

# 简单的die()语句

例如:

if (!file_exists('aa.txt')) {
    die('文件不存在');
} else {
    // 执行操作
}
// 如果上面die()被触发,那么这里echo接不被执行
echo 'ok';
1
2
3
4
5
6
7

简洁写法:

file_exits('aaa.txt') or die('文件不存在');
echo 'ok';
1
2

# 自定义错误处理器

创建自定义错误函数(处理器),该函数必须有能力处理至少两个参数(error_level和error_message),但是可以接受最多五个参数(error_file、error_line、error_context)

语法:

function error_function($error_level, $error_message, $error_file, $error_line, $error_context)
1

创建好后还需要调用set_error_handler()函数设置错误处理函数。

语法:

set_error_handler('error_function', E_WARNING); // 这里error_function对应上面创建的自定义处理器名,第二个参数为使用自定义错误处理器的错误级别
1

# 错误报告级别

这些错误报告级别是错误处理程序旨在处理的错误的不同的类型:

值 常量 描述
2 E_WARNING 非致命的 run-time 错误。不暂停脚本执行。
8 E_NOTICE Run-time 通知。脚本发现可能有错误发生,但也可能在脚本正常运行时发生。
256 E_USER_ERROR 致命的用户生成的错误。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_ERROR。
512 E_USER_WARNING 非致命的用户生成的警告。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_WARNING。
1024 E_USER_NOTICE 用户生成的通知。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_NOTICE。
4096 E_RECOVERABLE_ERROR 可捕获的致命错误。类似 E_ERROR,但可被用户定义的处理程序捕获。(参见 set_error_handler())
8191 E_ALL 所有错误和警告,除级别 E_STRICT 以外。(在 PHP 6.0,E_STRICT 是 E_ALL 的一部分)

# 错误触发器

需求:比如要接收一个年龄,如果数字大于120,就认为是一个错误

传统方法:

<?php
if ($age > 120) {
    echo '年龄错误';
    exit();
}
?>
1
2
3
4
5
6

使用触发器:

<?php
if ($age > 120) {
    // trigger_error('错误信息'[,'错误等级']); 这里错误等级为可选项,用于定义该错误的级别
    // 用户定义的级别包含以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE
    trigger_error('年龄错误'); // 这里是调用的系统默认的错误处理方式,我们也可以用自定义处理器
}
 
/**
 * 自定义处理器,与上面相同
 */
function myerror($error_level, $error_message) {
    echo 'error text';
}
 
//  同时需要改变系统默认的处理函数
set_error_handler('myerror', E_USER_WARNING); // 同上面,第一个参数为自定义函数的名称,第二个为错误级别【这里的错误级别通常为以下三种:E_USER_WARNING 、E_USER_ERROR 、E_USER_NOTICE】
// 现在再使用trigger_error就可以使用自定义的错误处理函数了
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# 错误日志

默认的根据php.ini中error_log配置,PHP向服务器的错误记录系统或文件发送错误记录,也可以通过使用error_log()函数可以向文件或远程目的地发送错误记录。

语法:

error_log(error[, type, destination, headers])
1

type部分一般用3,表示在文件后面追加错误信息,而不会覆盖原内容destination表示目的地,即存放的文件或远程目的地

如:error_log("$error_info",3,"errors.txt");

# 异常处理

# 基本语法

<?php
try {
    // 可能出现错误或异常的代码
    //catch 捕获  Exception是PHP已定义好的异常类
} catch (Exception $e) {
    // 对异常处理,方法:
    //1、自己处理
    //2、不处理,可以再次抛出 throw new Exception('xxx');
}
?>
1
2
3
4
5
6
7
8
9
10

处理处理程序应当包括:

  1. try - 使用异常的函数应该位于 "try" 代码块内。如果没有触发异常,则代码将照常继续执行。但是如果异常被触发,会抛出一个异常;
  2. throw - 这里规定如何触发异常。每一个 "throw" 必须对应至少一个 "catch";
  3. catch - "catch" 代码块会捕获异常,并创建一个包含异常信息的对象;

让我们触发一个异常:

<?php
/**
 * 创建可抛出一个异常的函数
 */
function checkNum($number) {
    if ($number > 1) {
        throw new Exception("Value must be 1 or below");
    }
 
    return true;
}
 
// 在 "try" 代码块中触发异常
try {
    checkNum(2);
    // 如果异常被抛出,那么下面一行代码将不会被输出
    echo 'If you see this, the number is 1 or below';
} catch (Exception $e) {
    // 捕获异常
    echo 'Message: ' . $e->getMessage();
}
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22

上面代码将获得类似这样一个错误:

Message: Value must be 1 or below
1

上面的代码抛出了一个异常,并捕获了它:

  1. 创建checkNum()函数,它检测数字是否大于 1,如果是,则抛出一个异常;
  2. 在 "try" 代码块中调用checkNum()函数;
  3. checkNum()函数中的异常被抛出;
  4. "catch"代码块接收到该异常,并创建一个包含异常信息的对象($e),通过从这个exception对象调用$e->getMessage(),输出来自该异常的错误消息;

不过,为了遵循“每个 throw 必须对应一个 catch”的原则,可以设置一个顶层的异常处理器来处理漏掉的错误。set_exception_handler()函数可设置处理所有未捕获异常的用户定义函数。

<?php
/**
 * 设置一个顶级异常处理器
 */
function myexception($e) {
    echo 'this is top exception';
}
 
// 修改默认的异常处理器
set_exception_handler("myexception");
try {
    $i = 5;
    if ($i < 10) {
        throw new Exception('$i must greater than 10');
    }
} catch (Exception $e) {
    // 处理异常
    echo $e->getMessage() . '<br/>';
 
    // 不处理异常,继续抛出
    throw new Exception('errorinfo'); // 也可以用throw $e 保留原错误信息;
}
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

创建一个自定义的异常类

<?php
class customException extends Exception {
    public function errorMessage() {
        $errorMsg = 'Error on line ' . $this->getLine() . ' in ' . $this->getFile() . ': <b>' . $this->getMessage() . '</b> is not a valid E-Mail address';
        return $errorMsg;
    }
}
 
// 使用
try {
    throw new customException('error message');
} catch (customException $e) {
    echo $e->errorMessage();
}
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

可以使用多个catch来返回不同情况下的错误信息

<?php
try {
    $i = 5;
    if ($i > 0) {
        throw new customException('error message'); // 使用自定义异常类处理
    }
    if ($i < -10) {
        throw new Exception('error2'); // 使用系统默认异常处理
    }
} catch (customException $e) {
    echo $e->getMessage();
} catch (Exception $e1) {
    echo $e1->getMessage();
}
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

异常的规则

  • 需要进行异常处理的代码应该放入 try 代码块内,以便捕获潜在的异常。
  • 每个try或throw代码块必须至少拥有一个对应的 catch 代码块。
  • 使用多个 catch 代码块可以捕获不同种类的异常。
  • 可以在try代码内的catch 代码块中再次抛出(re-thrown)异常。

简而言之:如果抛出了异常,就必须捕获它。

#PHP
上次更新: 2022/12/01, 11:09:34
PHP操作Zookeeper实践
PHP的Session运行机制

← PHP操作Zookeeper实践 PHP的Session运行机制→

最近更新
01
常用游戏反外挂技术总结
11-27
02
Golang开发实践万字总结
11-11
03
Redis万字总结
10-30
更多文章>
Theme by Vdoing | Copyright © 2011-2022 Ravior | 粤ICP备17060229号-3 | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式