PHP前端开发

如何在 PHP 函数中记录异常?

百变鹏仔 1个月前 (12-15) #PHP
文章标签 函数

在 php 函数中记录异常有两种方法:使用 try-catch 块捕获异常,并在 catch 块中处理它们。使用日志记录库记录异常,例如 monolog 或符合 psr-3 标准的库。

如何在 PHP 函数中记录异常?

异常是 PHP 中用来处理错误和异常情况的机制。在函数中记录异常可以确保即使在意外错误出现的情况下,应用程序也能继续运行。

使用 try-catch 块记录异常

立即学习“PHP免费学习笔记(深入)”;

最常见的方法是使用 try-catch 块:

<?php try {    // 代码可能引发异常的代码块    // ...} catch (Exception $e) {    // 异常处理代码    // ...}

try 块包含可能引发异常的代码。如果发生异常,它会被 catch 块捕获。$e 变量包含有关异常的信息,包括消息和跟踪信息。

使用日志记录库记录异常

还可以使用日志记录库来记录异常,例如 [Monolog](https://github.com/Seldaek/monolog) 或 [PSR-3](https://www.php-fig.org/psr/psr-3/) 兼容库。

<?php use MonologLogger;use MonologHandlerStreamHandler;// 创建日志记录器$logger = new Logger('my_app');// 添加流处理器$logger->pushHandler(new StreamHandler('app.log', Logger::ERROR));try {    // 代码可能引发异常的代码块    // ...} catch (Exception $e) {    // 记录异常到日志文件    $logger-&gt;error($e-&gt;getMessage(), ["exception" =&gt; $e]);}

实战案例

假设我们有一个函数 divide(),用于计算两数的商。如果除数为 0,该函数将引发 DivisionByZeroError 异常。

<?php function divide($numerator, $denominator) {    if ($denominator === 0) {        throw new DivisionByZeroError();    }    return $numerator / $denominator;}try {    $result = divide(10, 2);    echo "结果:$result";} catch (DivisionByZeroError $e) {    echo "发生除以 0 错误!";}

在上面的示例中,如果除数为 0,divide() 函数会引发 DivisionByZeroError 异常。catch 块会捕获此异常并打印一条错误消息。