自定义异常类能区分业务错误、携带上下文信息并统一处理逻辑,通过继承Exception类实现,如ValidationException可存储验证错误详情,提升代码可读性与维护性。

在php中,自定义异常类可以让你更精确地处理不同类型的错误情况。通过继承内置的 Exception 类,你可以创建具有特定用途的异常类型,从而提升代码的可读性和维护性。
为什么要自定义异常类?
PHP 默认的 Exception 类适用于大多数场景,但当项目复杂度上升时,使用单一异常类型会让错误处理变得混乱。自定义异常能帮助你:
- 区分不同业务场景的错误(如数据库异常、验证异常)
- 携带额外上下文信息(如错误码、请求参数)
- 统一项目中的异常处理逻辑
如何编写自定义异常类
自定义异常类只需继承 Exception 类即可。你可以添加新的属性或方法来扩展功能。
class ValidationException extends Exception { private $Errors = []; <pre class='brush:php;toolbar:false;'>public function __construct($message, $errors = [], $code = 0, Throwable $previous = null) { $this->errors = $errors; parent::__construct($message, $code, $previous); } public function getErrors(): array { return $this->errors; }
}
立即学习“PHP免费学习笔记(深入)”;
上面的例子定义了一个用于表单或数据验证失败的异常类,它额外保存了具体的错误字段信息。
实际使用示例
在业务逻辑中抛出并捕获自定义异常:
function validateUser(array $data) { $errors = []; if (empty($data['email'])) { $errors[] = '邮箱不能为空'; } if (empty($data['password']) || strlen($data['password']) < 6) { $errors[] = '密码至少6位'; } <pre class='brush:php;toolbar:false;'>if (!empty($errors)) { throw new ValidationException('验证失败', $errors); }
}
立即学习“PHP免费学习笔记(深入)”;
// 使用 try-catch 捕获 try { validateUser([’email’ =youjiankuohaophpcn ”, ‘password‘ => ‘123’]); } catch (ValidationException $e) { echo “提示:{$e->getMessage()}n”; foreach ($e->getErrors() as $error) { echo “- $errorn”; } }
扩展多种异常类型
你可以根据项目需要定义多个异常类,形成清晰的异常体系:
class DatabaseException extends Exception {} class ApiException extends Exception {} class PaymentException extends Exception {}
这样在捕获时就可以根据不同异常类型执行不同的恢复或记录策略。
基本上就这些。只要继承 Exception 类,按需添加构造逻辑和辅助方法,就能实现灵活可靠的错误控制机制。不复杂但容易忽略的是保持异常命名清晰、层级合理。