PHP代码优化需遵循PSR-12规范、分层架构、严格类型声明、重构冗余代码及配置环境隔离五方面:统一缩进与格式,分离业务/数据/表现层,启用strict_types与类型声明,拆分函数与封装重复逻辑,剥离配置至.env并动态加载。

如果您的PHP网站在运行过程中出现性能下降、维护困难或团队协作效率低等问题,则可能是由于代码结构混乱、缺乏统一规范所致。以下是优化PHP代码结构与遵循代码规范的具体方法:
一、采用PSR-12编码标准
PSR-12是PHP社区广泛采纳的代码风格规范,统一缩进、括号位置、空行和运算符间距等细节,可显著提升代码可读性与协作一致性。
1、使用4个空格进行缩进,禁止使用Tab字符。
2、控制结构关键字(如if、for、while)后必须保留一个空格,左大括号{必须与关键字同行且后跟一个空格。
立即学习“PHP免费学习笔记(深入)”;
3、方法声明时,function关键字与方法名之间无空格,左括号(紧跟方法名,右括号)后紧跟冒号:或{。
4、二元运算符(如+、==、===、&&)前后必须各保留一个空格。
5、使用PHP_CodeSniffer配合Squizlabs/PHP_CodeSniffer规则集自动检测并修复格式违规项。
二、实施分层架构设计
将业务逻辑、数据访问与表现层分离,避免混杂代码,增强模块独立性与测试可行性。
1、创建app/目录存放核心业务逻辑类,按功能划分子目录如app/Service/、app/Repository/。
2、在app/Repository/中定义接口(如UserRepositoryInterface),并在app/Repository/Impl/中提供具体实现。
3、控制器(Controller)仅负责接收请求、调用Service层方法、返回响应,不包含SQL语句或复杂计算。
4、视图(View)仅执行变量输出与基础条件渲染,禁用PHP脚本块中的函数调用或循环逻辑。
5、使用依赖注入容器(如PHP-DI或Symfony DI)管理类实例化关系,解除硬编码依赖。
三、引入类型声明与严格模式
启用PHP 7.0+的标量类型声明与返回类型声明,配合declare(strict_types=1),可提前暴露类型错误,降低运行时异常风险。
1、在每个PHP文件首行添加declare(strict_types=1);语句。
2、为所有函数参数添加类型提示,例如function calculateTotal(float $price, int $quantity): float。
3、为所有函数声明明确的返回类型,包括void、array、string、自定义类名等。
4、对数组参数使用array|iterable类型提示,并配合is_array()或is_iterable()做运行时校验作为补充。
5、在composer.json中配置"php": "^7.4 || ^8.0"确保环境兼容性。
四、重构冗余与重复代码
识别并消除重复逻辑、过长函数及过度嵌套,通过提取方法、合并条件、使用策略模式等方式提升可维护性。
1、将长度超过30行或嵌套层级超过3层的函数拆分为多个单一职责的小函数。
2、查找多处出现的相同SQL查询片段,将其封装为Repository接口中的独立方法。
3、将if-elseif-else链中重复使用的判断条件提取为私有方法并命名清晰,如isEligibleForDiscount()。
4、针对不同支付渠道(微信、支付宝、银联)的处理逻辑,定义PaymentStrategy接口并实现各自策略类。
5、使用PHPStan或Psalm静态分析工具扫描未使用的变量、不可达代码与类型不匹配路径。
五、标准化配置与环境隔离
将数据库凭证、API密钥、调试开关等敏感或变动参数从代码中剥离,实现运行时动态加载与环境差异化配置。
1、创建config/目录,下设config.php(通用配置)、env/目录存放.env.development、.env.production等文件。
2、使用vlucas/phpdotenv库在应用启动时自动加载对应环境的.env文件内容到$_ENV。
3、数据库连接参数统一由DbConfig类从环境变量读取,禁止在DAO类中硬编码host/user/pass。
4、日志级别(debug/info/warning/error)根据APP_ENV值动态设定,生产环境默认关闭debug日志输出。
5、在public/index.php入口文件顶部添加require __DIR__.'/../vendor/autoload.php';确保自动加载机制优先启用。











