| content |
## 自动代码审查报告
**分支**: pay-260519
**提交**: `eb5b4dbe1 ## 自动代码审查报告
**分支**: pay-260519
**提交**: `eb5b4dbe1e21990dc4ce9ae1f3ef659c98f1c761`
**提交人**: LITTLEMAIDI (11833999+littlemaidi@user.noreply.gitee.com)
**时间**: 2026-05-28 17:06:11
---
## 1. 审查摘要
- **代码质量评分**:6.0 / 10 分
- **总体评价**:业务链路覆盖较全(支付回调、退款、下单、消息推送等),但存在**高危 SQL 注入风险**、**事务状态管理混乱**及**全局变量滥用**等架构缺陷。代码中大量使用魔法数字、重复加载模型、错误处理机制不统一,导致可维护性与扩展性较差。
- **风险等级**:🔴 高
- **⚠️ 局限性说明**:提供的代码在 `create_community_shop_book_order` 方法末尾被截断,本次审查仅基于已提供片段。若截断部分包含核心支付或状态流转逻辑,建议补充后二次复核。
---
## 2. 问题详情
| 严重程度 | 文件/行号 | 问题描述 | 建议修改方案 | 代码示例 (可选) |
| :--- | :--- | :--- | :--- | :--- |
| 🔴 严重 | `refund_by_notify` ~L240 | `$log_where` 使用字符串拼接构造 WHERE 条件,若 `_id` 未严格过滤或未来传入恶意字符,将直接导致 **SQL 注入**。且 `$log_up` 同样为裸字符串,绕过框架安全转义。 | 废弃裸字符串拼接,全面改用 CI 查询构造器(Query Builder)或 `$this->db->escape()`。 | `$this->db->where('_relation_id', $order_data['_id'])<br>->where('_status', 1)<br>->where_in('_type', [5, 13])<br>->update('pay_log_table', $update_data);` |
| 🔴 严重 | 文件顶部 L7 | `$CI = &get_instance();` 定义在类外部。PHP 每次 `include/require` 该文件都会执行此赋值,破坏单例模式且可能在未初始化环境下报错。 | 移除全局定义,改为在类内部方法中按需获取,或在 `__construct()` 中赋值给类属性。 | `protected $CI;<br>public function __construct() { parent::__construct(); $this->CI =& get_instance(); }` |
| 🔴 严重 | `check_notify` L88-L150 | 在 `try` 块中手动调用 `$this->db->trans_rollback()` 后直接 `return`,但后续逻辑仍可能触发 `$this->db->trans_complete()`。CI 事务状态机在手动回滚后调用 `trans_complete()` 会返回 `FALSE` 并可能引发隐式状态冲突。 | 移除手动 `trans_rollback()`,统一交由 `trans_complete()` 根据 `trans_status()` 自动决定提交或回滚。 | `// 移除所有 $this->db->trans_rollback();<br>// 在方法末尾统一:<br>$this->db->trans_complete();<br>if ($this->db->trans_status() === FALSE) { return ['status'=>false, 'msg'=>'事务失败']; }` |
| 🟠 警告 | 全局多处 | 大量使用魔法数字(如 `-1, 1, 2, 3, 4, 5, 14, 58, 56, 9`)表示订单状态、支付渠道、短信模板等。硬编码导致后期维护极易出错。 | 提取为类常量或独立配置文件,增强语义化。 | `const STATUS_PENDING = -1; const STATUS_PAID = 1; const PAY_SCENE_WX = '5';` |
| 🟠 警告 | `send_success_msg` 等 | 方法内部频繁调用 `$this->load->model()`。虽然 CI 有加载缓存,但破坏了单一职责原则,增加耦合度与初始化开销。 | 统一在 `__construct()` 中预加载,或采用依赖注入思想按需传递。 | `public function __construct() { parent::__construct(); $this->load->model(['ahead_merchant_room_type_model', 'ahead_yc_notice_model', 'ahead_user_model']); }` |
| 🟠 警告 | `check_notify` L142 | `json_encode($e->getTrace(), 256)` 记录完整调用栈。生产环境高频支付失败时会导致日志文件暴增,且可能泄露服务器绝对路径等敏感信息。 | 仅记录异常核心信息、行号及关键业务标识。 | `doLog('支付失败: ' . $e->getMessage() . ' (Line:' . $e->getLine() . ') Order:' . $order_id, 'book_order');` |
| 🟡 建议 | `refund` / `check_notify` | 错误处理机制不统一:部分方法返回 `['status'=>false]` 数组,部分直接调用 `throwError()` 中断执行。调用方难以统一捕获。 | 统一契约:Model 层建议全部返回结构化数组,由 Controller 层统一处理异常或跳转。 | 保持全量 `return ['status' => false, 'msg' => '...', 'code' => 500];` 风格 |
| 🟡 建议 | `get_list` L308 | 循环内虽做了 `$merchant_business_model` 缓存,但变量命名易混淆,且未处理 `$order_info` 为空时的边界情况。 | 使用 `array_column` 批量查询,提升可读性与性能。 | `$ids = array_column($order_info, 'merchant_id');<br>$merchants = $this->ahead_merchant_model->get_batch(['_id' => $ids], '_id,_business_model');` |
---
## 3. 总结与行动建议
### 🔑 优先修复的关键问题
1. **立即修复 SQL 注入漏洞**:将 `refund_by_notify` 中的 `$log_where` 和 `$log_up` 替换为 CI 查询构造器链式调用,杜绝字符串拼接。
2. **规范事务生命周期**:移除 `check_notify` 中所有手动 `trans_rollback()`,统一在方法末尾调用 `trans_complete()`,并通过 `trans_status()` 判断结果。避免事务状态机紊乱导致的数据不一致。
3. **清理全局变量**:删除文件顶部的 `$CI = &get_instance();`,改为类属性或方法内局部变量,符合 PHP 面向对象规范。
### 🛠 后续重构与优化方向
1. **常量与枚举化**:建立 `OrderStatus`、`PayPlatform`、`PayScene` 等常量类或配置文件,替换所有魔法数字。可大幅提升代码可读性并降低误改风险。
2. **模型加载优化**:将高频使用的 Model 移至 `__construct()` 中统一加载。对于超长方法(如 `refund_by_notify` 超 200 行),建议按职责拆分为 `processRefund()`、`notifyThirdParty()`、`updateInventory()` 等私有方法。
3. **统一错误契约**:Model 层应作为纯数据与业务逻辑层,避免直接调用 `throwError()` 或输出视图。建议全量采用 `return ['status' => bool, 'msg' => string, 'data' => mixed]` 结构,由 Controller 层统一处理 HTTP 响应。
4. **日志脱敏与分级**:支付、退款等核心链路日志需进行敏感字段脱敏(如手机号、交易号掩码)。建议引入 `Monolog` 或 CI 内置日志分级(`log_message('error', ...)`),避免 `doLog` 泛滥。
5. **框架适配说明**:基于 `system/`、`application/models/` 结构判断,本项目高度疑似基于 **CodeIgniter 3** 架构(提示中 `phpci` 可能为笔误)。上述事务、查询构造器及模型加载建议均严格遵循 CI3 官方最佳实践。若实际为自研框架,请核对 `trans_start/complete` 与 `load->model` 的底层实现是否一致。
> 💡 **下一步建议**:优先完成安全与事务修复后,可引入 `PHPStan` 或 `PHP_CodeSniffer (PSR-12)` 进行静态扫描,逐步建立自动化代码质量门禁。如需对截断的 `create_community_shop_book_order` 进行深度审查,请补充完整代码。
---
*此 Issue 由代码审查服务自动创建*... |