2026-05-26 09:16:48 +00:00
|
|
|
|
# Plan — vr-shopxo-plugin 安全评估 + 票务链路审计
|
2026-04-15 05:53:39 +00:00
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
> 版本:v3.0 | 日期:2026-05-26 | Agent:council/SecurityEngineer
|
2026-04-20 01:45:33 +00:00
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
## 安全评估结论(Round 3 最终版)
|
2026-04-20 01:45:33 +00:00
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
**核心结论:支付链路安全水位中高,无 P0 漏洞。安全维度不应作为主攻方向阻塞项。**
|
2026-05-26 09:21:24 +00:00
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
| # | 问题 | 严重性 | 结论 |
|
|
|
|
|
|
|---|------|--------|------|
|
|
|
|
|
|
| S-1 | issueTicket() 并发竞态 | P0 建议 | 建议加唯一索引,可延后 |
|
|
|
|
|
|
| S-2 | FOR UPDATE SKIP LOCKED 概念澄清 | P2 | 概念混淆,防超卖依赖ShopXO原子UPDATE已有效 |
|
|
|
|
|
|
| S-3 | getVrSecret() 硬编码 fallback | P1 | 需确认生产环境 .env 配置 |
|
|
|
|
|
|
| S-4 | $goodsId 未定义导致 ClearCache 失效 | P3 Bug | 不影响票务安全,可延后 |
|
|
|
|
|
|
| S-5 | $goods['content'] XSS(管理面可控) | P3 | 管理面可控,可延后 |
|
2026-04-20 01:46:20 +00:00
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
## 安全行动项(优先级排序)
|
2026-04-16 00:11:57 +00:00
|
|
|
|
|
2026-05-26 09:26:46 +00:00
|
|
|
|
| 优先级 | 行动 | 说明 |
|
|
|
|
|
|
|--------|------|------|
|
|
|
|
|
|
| P1 | 确认生产环境 `.env` 配置 `VR_TICKET_SECRET` | 防止源码泄露后伪造票 |
|
|
|
|
|
|
| P1 | 添加唯一索引 `uk_order_seat(order_id, seat_info)` | 从根本上防止并发发票竞态 |
|
|
|
|
|
|
| P3 | 修复 `ClearCache($goodsId)` Bug | 使用 `$og['goods_id']` |
|
|
|
|
|
|
| P3 | `$goods['content']` 转义 | 防止富文本XSS |
|
2026-04-15 06:00:20 +00:00
|
|
|
|
|
2026-04-16 00:11:57 +00:00
|
|
|
|
---
|
2026-04-15 06:20:03 +00:00
|
|
|
|
|
2026-05-26 09:16:48 +00:00
|
|
|
|
## 投票
|
2026-04-20 01:46:20 +00:00
|
|
|
|
|
2026-05-26 09:16:48 +00:00
|
|
|
|
**议题:下一步主攻方向**
|
2026-05-26 09:32:34 +00:00
|
|
|
|
**投票:C(双线并行)**(Round 1/2/3/4 一致,不变)
|
|
|
|
|
|
|
|
|
|
|
|
**Round 4 核查确认**:
|
|
|
|
|
|
- S-4 Bug 确认,`ClearCache($goodsId)` 应为 `ClearCache($og['goods_id'])`
|
|
|
|
|
|
- S-3 硬编码确认,生产需配置 `.env`
|
|
|
|
|
|
- S-1 幂等已有 ShopXO 保护,延后加唯一索引
|
|
|
|
|
|
- BackendArchitect P0 重分类背书:无 P0 安全漏洞
|