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 428 from issue
id
428
repo_id
21
index
148
poster_id
1
original_author
original_author_id
0
name
🔍 代码审查报告:pay-260616 - 自助转房
content
## 自动代码审查报告 **分支**: pay-260616 **提交**: `15f743dd2
## 自动代码审查报告 **分支**: pay-260616 **提交**: `15f743dd2010652b7e895a1426cb648718777011` **提交人**: LITTLEMAIDI (11833999+littlemaidi@user.noreply.gitee.com) **时间**: 2026-06-01 17:07:48 --- ## 1. 审查摘要 - **代码质量评分**:5.5 / 10 分 - **总体评价**:代码实现了较为完整的业务链路(预订、支付、日志、配置读取等),但存在明显的历史技术债。核心问题集中在**安全规范缺失**(硬编码密钥、SQL拼接、未过滤输入)、**现代 PHP 兼容性不足**(使用已废弃函数)、**框架生命周期破坏**(滥用 `exit/die` 与输出缓冲)以及**控制器臃肿**。测试代码与生产逻辑高度耦合,需进行架构级梳理。 - **风险等级**:🔴 高 ## 2. 问题详情 | 严重程度 | 文件/行号 | 问题描述 | 建议修改方案 | 代码示例 (可选) | | :--- | :--- | :--- | :--- | :--- | | 🔴 严重 | `common_helper.php`<br>`alioss_addObject` | 硬编码阿里云 OSS `accessId` 与 `accessKey`,极易随代码库泄露,导致云存储被恶意读写或产生高额账单。 | 移至 `application/config/oss.php` 或环境变量,通过 CI 配置类加载。 | `$param = $CI->config->item('ali_oss');`<br>`$obj = new Alioss($param);` | | 🔴 严重 | `common_helper.php`<br>`get_printer` | 使用字符串直接拼接构建 SQL `WHERE` 条件(如 `'_shop_id= ' . $shop_id`),未使用查询构造器或参数绑定,存在 SQL 注入风险。 | 统一使用 CI 查询构造器数组语法或 `$this->db->where()`,框架会自动转义。 | `$where = ['_shop_id' => $shop_id, '_status' => 1];`<br>`if ($checkstand_id) $where['FIND_IN_SET'] = $checkstand_id;`<br>`$this->db->where($where)->get()->row_array();` | | 🔴 严重 | `common_helper.php`<br>`decodeUnicode` | 使用 `create_function` 创建匿名函数。该函数在 PHP 7.2 已废弃,PHP 8.0 彻底移除,升级后将直接抛出致命错误。 | 替换为现代 PHP 匿名函数语法。 | `preg_replace_callback('/\\\\u([0-9a-f]{4})/i', function($m) { return mb_convert_encoding(pack("H*", $m[1]), "UTF-8", "UCS-2BE"); }, $str);` | | 🟠 警告 | `TestHlj.php`<br>`jsonEcho` | 混用 `ob_end_clean()`、`flush()`、`die()` 强行中断执行,破坏 CI 框架的 Output 类、Hook 机制及后续中间件执行,易引发 `Headers already sent` 错误。 | 移除输出缓冲控制,使用 CI 标准输出或封装统一响应组件。 | `$this->output->set_content_type('application/json')->set_output(json_encode($result, JSON_UNESCAPED_UNICODE));` | | 🟠 警告 | `TestHlj.php` / `Order.php` | 直接读取 `$_GET`、`$_REQUEST`、`php://input`,绕过 CI 输入过滤与 XSS 防护,且未做类型校验或默认值处理。 | 使用 CI 输入类 `$this->input->get()` / `$this->input->post()`,结合 `xss_clean` 或表单验证规则。 | `$this->params = json_decode($this->input->raw_input_stream, true) ?: [];`<br>`$order_id = $this->input->get('order_id', TRUE);` | | 🟠 警告 | `common_helper.php`<br>`curlRequest` | `CURLOPT_SSL_VERIFYPEER => false` 禁用 SSL 证书验证,在公网环境下易遭受中间人攻击(MITM),导致敏感数据(如支付回调、短信接口)被劫持。 | 生产环境必须开启验证,并配置系统 CA 证书路径。 | `curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);`<br>`curl_setopt($curl, CURLOPT_CAINFO, '/etc/ssl/certs/ca-certificates.crt');` | | 🟡 建议 | `TestHlj.php` | 大量硬编码测试数据(`merchant_id=1281`, `uid=66` 等),且包含 `exit('ok')`、`var_dump` 等调试语句,直接合并至主分支会污染生产环境。 | 测试控制器应增加环境守卫,或迁移至独立测试目录(如 `tests/`),生产代码严禁保留调试输出。 | `if (ENVIRONMENT !== 'testing') { show_error('此接口仅限测试环境'); }` | | 🟡 建议 | `common_helper.php` | 函数命名风格混乱(`doLog` vs `do_log`、`AliSendSMS` vs `sendSMS`),不符合 PSR-12 及 PHP 社区 `snake_case` 惯例,降低可读性。 | 统一使用 `snake_case`,移除冗余别名函数,保留单一入口。 | 统一为 `do_log()`,删除 `doLog()` 包装层。 | | 🟡 建议 | `Ahead_shop_config_second_model.php`<br>`get_shop_setting` | `switch` 分支长达 100+ 行,维护成本极高;且静态缓存 `self::$shop_config[$shop_id]` 未区分商户维度,多租户场景下可能串数据。 | 使用配置映射数组或动态属性访问;缓存键改为 `md5($merchant_id . '_' . $shop_id)`。 | `return $data[$field] ?? $default;`<br>`$cacheKey = $merchant_id . '_' . $shop_id;` | | 🟡 建议 | `Order.php`<br>`buyRenewalPackage` / `createOrder` | 单个方法超过 150 行,混合了参数校验、订单创建、支付路由(微信/国通)、缓存读取等逻辑,违反单一职责原则(SRP)。 | 拆分为独立服务类(如 `PaymentRouterService`、`OrderCreationService`),控制器仅负责接收请求与返回结果。 | `$paymentService = new PaymentService();`<br>`$result = $paymentService->process($param);` | ## 3. 总结与行动建议 ### 🔑 优先修复的关键问题 1. **安全漏洞清零**:立即移除 `common_helper.php` 中的 OSS 硬编码凭证,改用配置中心或 `.env` 管理;修复 `get_printer` 中的 SQL 拼接逻辑,全面切换至 CI 查询构造器。 2. **PHP 版本兼容**:全局替换 `create_function` 为匿名函数,确保代码兼容 PHP 7.4+ / 8.x。 3. **输入过滤与框架规范**:禁止直接使用 `$_GET/$_POST/$_REQUEST`,统一通过 `$this->input->get()` 获取;移除控制器中的 `ob_*` 与 `die()`,改用框架标准输出流。 ### 🛠 后续重构与优化方向 1. **控制器瘦身与服务化**:`TestHlj.php` 与 `Order.php` 属于典型的“胖控制器”。建议将支付路由、订单组装、配置读取等逻辑下沉至 `application/services/` 或 `application/libraries/`,控制器仅保留路由分发与响应格式化。 2. **统一响应与异常处理**:当前代码混用 `jsonEcho`、`echo json_encode`、`exit`、`throwError`。建议封装全局 `ApiResponse` 组件,结合 CI 的 `Hooks` 或自定义异常处理器,实现统一的状态码、消息体与日志记录。 3. **配置与缓存优化**:`Ahead_shop_config_second_model` 的静态缓存缺乏失效机制与多租户隔离。建议引入 Redis 缓存层,设置合理的 TTL,并在后台修改配置时主动清除缓存。 4. **测试代码隔离**:`TestHlj.php` 中的大量硬编码与调试逻辑应通过 `ENVIRONMENT` 常量隔离,或迁移至 PHPUnit/Codeception 测试套件,避免测试逻辑侵入生产代码库。 > 💡 **框架适配说明**:从代码结构(`BASEPATH`、`$this->load->`、`Simple_model` 基类等)判断,当前项目实际基于 **CodeIgniter 3** 架构。上述建议均严格遵循 CI3 最佳实践与现代 PHP 开发规范。若项目确为内部定制的 `phpci` 框架,请核对上述 CI3 特性(如 `$this->input`、`$this->output`、查询构造器)是否被完整继承或替换,必要时查阅对应框架的官方文档进行适配。 --- *此 Issue 由代码审查服务自动创建*
...
milestone_id
0
priority
0
is_closed
0
is_pull
0
num_comments
0
ref
deadline_unix
0
created_unix
1780304868
updated_unix
1780304868
closed_unix
0
is_locked
0
content_version
0
time_estimate
0
Delete
Cancel