如何在 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->error($e->getMessage(), ["exception" => $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 块会捕获此异常并打印一条错误消息。