# danding_points 评审报告 ## 修复前问题清单 (3项) | # | 严重度 | 问题 | 文件 | |---|--------|------|------| | 1 | **中** | `except Exception` 捕获后无日志记录、无rollback,吞没错误导致调试困难 | api.py:89,161,232 | | 2 | **中** | `ensure_user_exists` 在事务锁定区域内自行开新连接(conn=None),可能死锁或数据不一致 | api.py + database.py | | 3 | **低** | `set_points` 不更新 `total_spent`/`total_earned`,积分统计不准确 | api.py | ## 修复内容 ### api.py (303行) - 所有 `except` 块添加 `logger.error()` + `conn.rollback()` + `except Exception as e` - 添加 `import logging` + `logger = logging.getLogger(__name__)` - 调用 `ensure_user_exists(user_id, conn)` 传入已有连接 ### database.py (104行) - `ensure_user_exists` 签名改为 `(self, user_id: str, conn=None)` - 复用已有连接时不创建新连接、不commit/close;无conn时自行创建并管理生命周期 ## 验证结果 (9/9 ✓) - ✓ logging import & logger - ✓ 3x logger.error + 3x conn.rollback() + 3x except Exception as e - ✓ 调用方传conn、db定义接受conn - ✓ 无bare except - ✓ SQLite数据库无需HTTP timeout ## 代码质量总结 修复后评级:**B** (SQLite存储层设计合理,错误处理已完善)