---
paths:
  - "**/*.php"
  - "**/composer.json"
---

# PHP 编码风格

> 此文件在 [common/coding-style.md](../common/coding-style.md) 的基础上扩展了 PHP 相关内容。

## 标准

* 遵循 **PSR-12** 的格式化和命名约定。
* 在应用程序代码中优先使用 `declare(strict_types=1);`。
* 在所有新代码允许的地方使用标量类型提示、返回类型和类型化属性。

## 不可变性

* 对于跨越服务边界的数据，优先使用不可变的 DTO 和值对象。
* 在可能的情况下，对请求/响应负载使用 `readonly` 属性或不可变构造函数。
* 对于简单的映射使用数组；将业务关键的结构提升为显式类。

## 格式化

* 使用 **PHP-CS-Fixer** 或 **Laravel Pint** 进行格式化。
* 使用 **PHPStan** 或 **Psalm** 进行静态分析。
* 将 Composer 脚本纳入版本控制，以便在本地和 CI 中运行相同的命令。

## 错误处理

* 对于异常状态抛出异常；避免在新代码中返回 `false`/`null` 作为隐藏的错误通道。
* 在框架/请求输入到达领域逻辑之前，将其转换为经过验证的 DTO。

## 参考

有关更广泛的服务/仓库分层指导，请参阅技能：`backend-patterns`。
