70 lines
2.3 KiB
Markdown
70 lines
2.3 KiB
Markdown
# 重复消息问题修复测试
|
|
|
|
## 问题描述
|
|
用户在聊天页面发送一条消息时,数据库中保存了两条相同内容的用户消息:
|
|
1. 第一条:通过WebSocket处理器保存,包含完整的用户信息
|
|
2. 第二条:通过REST API保存,缺少部分用户信息
|
|
|
|
## 根本原因
|
|
前端`sendMessage`方法中存在双重保存机制:
|
|
1. WebSocket发送 - 后端WebSocket处理器会保存消息
|
|
2. REST API调用 - 前端额外调用`chatApi.createMessage`保存消息
|
|
|
|
## 修复方案
|
|
1. **前端修复**:移除前端`chat.ts`中`sendMessage`方法里的`chatApi.createMessage`调用,只保留WebSocket发送
|
|
2. **后端修复**:创建专门的WebSocket方法`sendChatMessageForWebSocket`,避免重复保存用户消息
|
|
|
|
## 修复内容
|
|
### 前端修改
|
|
文件:`web/src/stores/chat.ts`
|
|
- 移除了第69-82行的REST API调用
|
|
- 添加了注释说明修复原因
|
|
- 保留WebSocket发送逻辑
|
|
|
|
### 后端修改
|
|
文件:`backend-single/src/main/java/com/emotion/service/AiChatService.java`
|
|
- 新增`sendChatMessageForWebSocket`方法接口
|
|
|
|
文件:`backend-single/src/main/java/com/emotion/service/impl/AiChatServiceImpl.java`
|
|
- 实现`sendChatMessageForWebSocket`方法,只保存AI回复,不保存用户消息
|
|
|
|
文件:`backend-single/src/main/java/com/emotion/service/WebSocketService.java`
|
|
- 修改WebSocket处理器调用新的`sendChatMessageForWebSocket`方法
|
|
|
|
## 测试步骤
|
|
1. 启动后端服务
|
|
2. 启动前端服务
|
|
3. 登录用户账号
|
|
4. 发送一条测试消息
|
|
5. 检查数据库中是否只有一条用户消息记录
|
|
|
|
## 预期结果
|
|
- 数据库中只保存一条用户消息
|
|
- 消息包含完整的用户信息(user_id, user_type, coze_role等)
|
|
- AI回复正常工作
|
|
- 前端显示正常
|
|
|
|
## 验证SQL
|
|
```sql
|
|
-- 查看最新的消息记录
|
|
SELECT id, conversation_id, content, sender, user_id, user_type, coze_role, create_by, create_time
|
|
FROM message
|
|
WHERE conversation_id = '你的会话ID'
|
|
ORDER BY create_time DESC
|
|
LIMIT 10;
|
|
|
|
-- 检查是否还有重复消息
|
|
SELECT content, COUNT(*) as count
|
|
FROM message
|
|
WHERE conversation_id = '你的会话ID'
|
|
AND sender = 'user'
|
|
AND create_time > '2025-07-25 16:00:00'
|
|
GROUP BY content
|
|
HAVING COUNT(*) > 1;
|
|
```
|
|
|
|
## 注意事项
|
|
- 此修复只影响新发送的消息
|
|
- 历史重复消息需要手动清理
|
|
- 确保WebSocket连接正常工作
|