sqlite-web 0.7.2
gitea.db
issue
Create
Query
access
access_token
action
action_artifact
action_run
action_run_index
action_run_job
action_runner
action_runner_token
action_schedule
action_schedule_spec
action_task
action_task_output
action_task_step
action_tasks_version
action_variable
app_state
attachment
auth_token
badge
branch
collaboration
comment
commit_status
commit_status_index
commit_status_summary
commit_sync_log
commit_sync_status
dbfs_data
dbfs_meta
deploy_key
email_address
email_hash
external_login_user
follow
gpg_key
gpg_key_import
hook_task
issue
issue_assignees
issue_content_history
issue_dependency
issue_index
issue_label
issue_pin
issue_user
issue_watch
label
language_stat
lfs_lock
lfs_meta_object
login_source
milestone
mirror
notice
notification
oauth2_application
oauth2_authorization_code
oauth2_grant
org_user
package
package_blob
package_blob_upload
package_cleanup_rule
package_file
package_property
package_version
project
project_board
project_issue
protected_branch
protected_tag
public_key
pull_auto_merge
pull_request
push_mirror
reaction
release
renamed_branch
repo_archiver
repo_hidden_file
repo_indexer_status
repo_license
repo_redirect
repo_topic
repo_transfer
repo_unit
repository
review
review_state
secret
session
sqlite_sequence
star
stopwatch
system_setting
task
team
team_invite
team_repo
team_unit
team_user
topic
tracked_time
two_factor
upload
user
user_badge
user_blocking
user_open_id
user_redirect
user_setting
version
watch
webauthn_credential
webhook
Toggle helper tables
Structure
Content
Query
Insert
Drop
Import
Export
Delete row 451 from issue
id
451
repo_id
21
index
164
poster_id
1
original_author
original_author_id
0
name
🔍 代码审查报告:pay-260519 - 1
content
## 自动代码审查报告 **分支**: pay-260519 **提交**: `473df92ce
## 自动代码审查报告 **分支**: pay-260519 **提交**: `473df92ce3abc56c6dcc8b61b18f91afcca7a540` **提交人**: LITTLEMAIDI (11833999+littlemaidi@user.noreply.gitee.com) **时间**: 2026-06-02 10:14:47 --- ## 1. 审查摘要 - **代码质量评分**:4.5 / 10 分 - **总体评价**:该文件承载了核心订单计价与组装逻辑,业务场景复杂。但代码存在**财务精度计算隐患、SQL注入风险、调试代码残留、重复赋值覆盖**等严重问题。方法体极度臃肿,违反单一职责原则,且大量使用魔法数字与不规范命名,可维护性与扩展性较差。 - **风险等级**:🔴 高 > 📌 **框架说明**:代码中 `defined('BASEPATH')`、`get_instance()`、`$this->CI->load->model()` 等特征高度符合 **CodeIgniter 3** 架构规范,与提示中的 `phpci` 框架可能存在差异。以下审查基于 CI3 最佳实践及现代 PHP 标准。代码末尾存在截断(`$result['have_good`),部分逻辑未完全展示,审查基于已提供内容。 ## 2. 问题详情 | 严重程度 | 文件/行号 | 问题描述 | 建议修改方案 | 代码示例 (可选) | | :--- | :--- | :--- | :--- | :--- | | 🔴 严重 | ~第380行 | **生产环境残留调试输出**:`echo $vip_upgrade_data_actual_pay;` 会破坏 HTTP 响应流,导致 JSON/XML 解析失败或前端白屏。 | 立即移除 `echo`,改用框架日志记录。 | `log_message('debug', 'VIP升级计算金额: ' . $vip_upgrade_data_actual_pay);` | | 🔴 严重 | 全文多处 | **浮点数精度丢失风险**:金额计算直接使用 `* / +`(如 `$goods_actual_pay * $vip_discount_rate`),PHP 浮点运算易产生 `0.0000000001` 误差,财务场景致命。 | 统一使用 `bcmath` 扩展函数,并在累加/返回前严格保留2位小数。 | `$actual_pay = bcadd($actual_pay, $goods_actual_pay, 2);`<br>`$discounted = bcmul($price, $rate, 2);` | | 🔴 严重 | ~第265行 | **SQL 注入隐患**:`"wares_package._package_id in (" . implode(",", $id_array['package_id']) . ")"` 未对输入做类型强转,恶意构造可注入 SQL。 | 强制转为整型数组,或使用 CI3 查询构造器 `where_in()`。 | `$ids = array_map('intval', $id_array['package_id']);`<br>`$pack_goods_where = "wares_package._package_id IN (" . implode(',', $ids) . ")";` | | 🟠 警告 | ~第225-227行 | **逻辑覆盖错误**:`$order['_prime_service_charge']` 被连续赋值两次,后者 `$service_charge` 覆盖前者 `$prime_after_paid_service_charge`,导致业务数据错乱。 | 核对业务意图,删除冗余赋值,保留正确变量。 | `$order['_prime_service_charge'] = $prime_after_paid_service_charge;`<br>`// 删除下方重复的 $order['_prime_service_charge'] = $service_charge;` | | 🟠 警告 | 全文多处 | **重复加载模型**:在循环/分支内频繁调用 `$this->CI->load->model()`,增加不必要的 I/O 与内存开销。 | 统一在 `__construct()` 或方法入口处加载,CI3 模型加载本身具备懒加载特性,无需重复调用。 | `public function __construct() {`<br>` $this->CI =& get_instance();`<br>` $this->CI->load->model(['Ahead_vip_level_model', 'Ahead_merchant_goods_model', 'Ahead_goods_price_rooms_model']);`<br>`}` | | 🟠 警告 | ~第130行 | **魔法数字泛滥**:`100`, `-1`, `1`, `7`, `9999999999999` 等硬编码散落各处,业务规则变更时极易遗漏。 | 提取为类常量,增强语义与可维护性。 | `private const DISCOUNT_BASE = 100;`<br>`private const STATUS_DISABLED = -1;`<br>`private const MAX_REWARD_AMOUNT = 9999999999999;` | | 🟡 建议 | 全文 | **违反 PSR-12 规范**:属性命名混用驼峰与下划线(`$supermarketRoomName` vs `$room_id`),方法带 `_` 前缀,大量 `public` 属性暴露内部状态。 | 统一使用驼峰命名,将非接口属性改为 `private/protected`,移除方法名前缀。 | `private $supermarketRoomName = '自助扫码厅';`<br>`private $roomId = 0;`<br>`private function createInsertInfosData(...)` | | 🟡 建议 | `getOrderTypeInfo` | **方法过长且职责混杂**:单方法超 500 行,混合了商品查询、套餐计算、VIP折扣、服务费、优惠券抵扣、免单逻辑等,违反 SRP。 | 按业务域拆分为独立私有方法或策略类,如 `calculateGoodsPrice()`, `applyVipDiscount()`, `computeServiceCharge()`。 | 使用提取方法重构(Extract Method),保持单方法行数 < 80。 | ## 3. 总结与行动建议 ### 🔑 优先修复的关键问题(P0) 1. **立即删除 `echo` 调试语句**,避免线上接口响应污染。 2. **修复 SQL 注入风险**:对所有动态拼接的 `IN` 条件执行 `array_map('intval', $ids)` 过滤。 3. **修正重复赋值逻辑**:确认 `$order['_prime_service_charge']` 的正确业务含义,删除覆盖代码。 4. **引入 `bcmath` 金额计算规范**:所有涉及价格的乘除加减必须使用 `bcmul`/`bcadd`/`bcsub`,并在最终返回前统一 `round($val, 2)`。 ### 🛠 后续重构与优化方向 1. **架构拆分(策略模式/职责分离)**: - 将 `getOrderTypeInfo` 拆分为 `OrderCalculator` 服务类。 - 使用策略模式处理不同订单类型(`case '1'`, `case '2'` 等),避免巨型 `switch`。 - 示例结构: ```php interface OrderTypeStrategy { public function calculate(array $params): array; } class GoodsOrderStrategy implements OrderTypeStrategy { ... } class RoomPackageStrategy implements OrderTypeStrategy { ... } ``` 2. **数据校验与异常处理**: - 使用 CI3 的 `Form_validation` 或自定义 DTO 对 `$id_array`, `$goods_quantity` 进行强类型校验。 - 将 `throwError()` 替换为抛出标准异常(如 `throw new \InvalidArgumentException(...)`),便于全局捕获与日志追踪。 3. **框架规范对齐**: - 若确为 CI3 环境,建议将模型加载移至 `config/autoload.php` 或构造函数中。 - 数据库查询优先使用 `$this->CI->db->where_in()` 等 Query Builder 方法,彻底杜绝字符串拼接。 4. **代码规范升级**: - 逐步引入 PHP 7+ 类型声明(如 `public function getOrderTypeInfo(string $type, array $idArray, array $goodsQuantity, int $getActualPay = -1, array &$goodsReward = []): array`)。 - 清理历史注释(如 `//add by nan 22.07.11`),改用 Git 提交记录追溯变更。 > 💡 **提示**:由于代码在末尾被截断,部分订单组装逻辑(如 `have_goods` 字段赋值、最终返回结构)未完整展示。建议在修复上述高危问题后,补充完整代码进行二次审查,并补充单元测试覆盖核心计价分支。 --- *此 Issue 由代码审查服务自动创建*
...
milestone_id
0
priority
0
is_closed
0
is_pull
0
num_comments
0
ref
deadline_unix
0
created_unix
1780366487
updated_unix
1780366487
closed_unix
0
is_locked
0
content_version
0
time_estimate
0
Delete
Cancel