Files
xyzw_web_helper/MD说明文件夹/问题修复-批量发车激活账号v3.9.8.md

433 lines
10 KiB
Markdown
Raw Permalink Normal View History

2025-10-17 20:56:50 +08:00
# 问题修复:批量发车添加账号激活逻辑 v3.9.8
## 🚀 概述
**问题**
- v3.9.7 修改后,统计准确了 ✅
- 但服务器**完全不响应** `car_getrolecar` 命令 ❌
- 所有6个账号都超时20秒
**根本原因**
- 批量自动化连接后直接查询车辆
- 服务器需要先"激活"账号状态,才会响应游戏命令
- 缺少初始化步骤
**解决方案**
- 在查询车辆前先获取角色信息(`role_getroleinfo`
- 模拟正常游戏流程
---
## 🔍 问题分析
### v3.9.7 的问题(统计正确,但查询失败)
**批量自动化流程**
```
1. WebSocket连接成功 ✅
2. 等待2秒 ✅
3. 📤 发送消息: car_getrolecar {} ← 发送了
4. 💓 发送心跳消息 ← 心跳正常
5. 💓 发送心跳消息 ← 继续心跳
6. 💓 发送心跳消息 ← 还是心跳
7. ❌ 20秒后超时 ← 没有收到 car_getrolecarresp
```
**服务器行为**
- ✅ WebSocket连接正常
- ✅ 心跳消息正常收发
-**完全忽略** `car_getrolecar` 命令
-**不返回任何响应**(既不是成功也不是错误)
---
### 游戏功能模块为什么成功?
**游戏功能模块的流程**
```
1. WebSocket连接成功 ✅
2. 用户在页面上点击"查询车辆"
3. 此时账号可能已经在其他页面获取过角色信息
4. 📤 发送消息: car_getrolecar {}
5. 📨 [token_xxx] car_getrolecarresp ← 立即收到响应!
6. ✅ 查询到 4 辆车
```
**关键差异**
- 游戏功能模块的账号通常已经"激活"过
- 批量自动化是新连接,直接查询
---
### 正常游戏的初始化流程
**观察正常游戏行为**
```
1. WebSocket连接成功
2. 📤 发送消息: role_getroleinfo {} ← 获取角色信息(账号"激活"
3. 📨 role_getroleinforesp ← 服务器响应
4. 之后所有游戏命令都能正常响应
```
**服务器逻辑推测**
```javascript
// 服务器端伪代码
if (!session.isActivated) {
// 账号未激活,忽略游戏命令
if (cmd !== 'role_getroleinfo') {
return; // 不响应
}
}
// 账号已激活,正常处理游戏命令
handleGameCommand(cmd, params);
```
---
## 🛠️ 解决方案 v3.9.8
### 核心改进:模拟正常游戏流程
**在查询车辆前,先获取角色信息来激活账号**
---
### 修改详情
**位置**`src/stores/batchTaskStore.js` 第1149-1164行
#### 修改前v3.9.7
```javascript
try {
// 第1步查询车辆
console.log(`🚗 [${tokenId}] 开始查询俱乐部车辆...`)
const queryResponse = await tokenStore.sendMessageAsync(
tokenId,
'car_getrolecar',
{},
20000
)
// ...
}
```
**问题**
- ❌ 连接后直接查询车辆
- ❌ 账号未激活
- ❌ 服务器不响应
---
#### 修改后v3.9.8
```javascript
try {
// 第0步先获取角色信息激活账号
console.log(`👤 [${tokenId}] 获取角色信息(激活账号)...`)
try {
await tokenStore.sendMessageAsync(tokenId, 'role_getroleinfo', {}, 5000)
console.log(`✅ [${tokenId}] 角色信息获取成功`)
} catch (error) {
console.warn(`⚠️ [${tokenId}] 角色信息获取失败: ${error.message},继续尝试查询车辆`)
}
// 等待一下,让服务器处理
await new Promise(resolve => setTimeout(resolve, 1000))
// 第1步查询车辆
console.log(`🚗 [${tokenId}] 开始查询俱乐部车辆...`)
const queryResponse = await tokenStore.sendMessageAsync(
tokenId,
'car_getrolecar',
{},
20000
)
// ...
}
```
**改进**
- ✅ 先获取角色信息(激活账号)
- ✅ 使用 try-catch 包裹,即使获取失败也继续
- ✅ 等待1秒让服务器处理
- ✅ 然后再查询车辆
- ✅ 模拟正常游戏流程
---
## ✅ 优势
### 1. 模拟正常游戏流程
- ✅ 先获取角色信息,激活账号状态
- ✅ 然后再执行游戏命令
- ✅ 符合服务器的预期行为
### 2. 容错性强
- ✅ 角色信息获取失败也不会中断流程
- ✅ 只是警告,然后继续尝试查询车辆
- ✅ 最大程度保证任务执行
### 3. 适度延迟
- ✅ 只增加1秒延迟等待服务器处理
- ✅ 不会显著影响整体执行速度
- ✅ 角色信息获取本身也很快(< 1秒
### 4. 易于调试
- ✅ 清晰的日志输出
- ✅ 可以看到账号激活是否成功
- ✅ 便于排查问题
---
## 📊 预期效果
### v3.9.7(修改前)
```
✅ WebSocket连接成功
⏳ 等待连接稳定... (2秒)
📤 发送消息: car_getrolecar {}
💓 心跳消息... (不断收发)
❌ 20秒后超时服务器完全不响应
```
**问题**:服务器忽略 `car_getrolecar` 命令
---
### v3.9.8(修改后)
```
✅ WebSocket连接成功
⏳ 等待连接稳定... (2秒)
👤 获取角色信息(激活账号)...
📤 发送消息: role_getroleinfo {}
📨 role_getroleinforesp ← 服务器响应
✅ 角色信息获取成功
⏳ 等待1秒让服务器处理...
📤 发送消息: car_getrolecar {}
📨 car_getrolecarresp ← 服务器响应!
✅ 查询到 4 辆车 ← 预期快速成功!
🔄 开始批量刷新车辆...
✅ 刷新车辆成功
🎁 开始批量收获...
✅ 收获车辆成功
🚀 开始批量发送...
✅ 发送车辆成功
```
**改进**
- ✅ 服务器正常响应 `car_getrolecar`
- ✅ 查询车辆快速成功1-2秒
- ✅ 整体流程顺畅可靠
---
## 🧪 验证步骤
### 1. 清除浏览器缓存
```
F12 → Application → Storage → Clear site data
```
**原因**:确保使用新的代码逻辑
---
### 2. 重启开发服务器
```bash
# Ctrl+C 停止
# 然后重新启动
npm run dev
```
---
### 3. 批量测试
1. 打开批量自动化面板
2. 选择**2-6个账号**
3. 只勾选**"发车"**任务
4. 点击"开始执行"
---
### 4. 观察日志
#### 期望结果(成功✅)
```
🎯 开始执行 Token: 805服-0-xxx
✅ WebSocket连接成功
⏳ 等待连接稳定...
📌 执行任务 [1/1]: sendCar
👤 [token_xxx] 获取角色信息(激活账号)... ← 新增步骤
✅ [token_xxx] 角色信息获取成功 ← 新增日志
🚗 [token_xxx] 开始查询俱乐部车辆...
✅ [token_xxx] 查询到 4 辆车 ← 应该1-2秒内完成
🔄 [token_xxx] 开始批量刷新车辆1次...
✅ [token_xxx] 刷新车辆成功: carId
🎁 [token_xxx] 开始批量收获...
✅ [token_xxx] 收获车辆成功: carId
🚀 [token_xxx] 开始批量发送...
✅ [token_xxx] 发送车辆成功: carId
✅ Token完成: 805服-0-xxx
```
**关键指标**
- ✅ 看到"获取角色信息(激活账号)"日志
- ✅ 看到"角色信息获取成功"日志
- ✅ 查询车辆应该在1-2秒内完成而不是20秒超时
- ✅ 整体流程顺畅
---
#### 如果仍然失败unlikely
**日志模式**
```
👤 [token_xxx] 获取角色信息(激活账号)...
⚠️ [token_xxx] 角色信息获取失败: 请求超时: role_getroleinfo (5000ms),继续尝试查询车辆
🚗 [token_xxx] 开始查询俱乐部车辆...
❌ 20秒后超时
```
**说明**
- 即使角色信息获取失败了,也会尝试查询车辆
- 如果查询车辆还是超时,说明问题更复杂
**可能原因**
1. 服务器端限制更严格(需要更多初始化命令)
2. 反批量检测(需要增加账号间隔)
3. 账号未加入俱乐部(这是之前的结论)
**下一步方案**
- 增加更多初始化命令(如获取队伍信息、背包信息等)
- 增加账号间隔3秒 → 10秒
- 降低并发6 → 1
---
## 📝 文件修改清单
### 修改文件
1.`src/stores/batchTaskStore.js`
- 第1150-1160行添加账号激活逻辑
### 新增文档
1.`MD说明/问题修复-批量发车激活账号v3.9.8.md` - 本文档
---
## 🔄 版本信息
- **版本号**v3.9.8
- **修复日期**2025-10-08
- **影响范围**:批量自动化 - 发车任务
- **向后兼容**:✅ 完全兼容
- **破坏性变更**:❌ 无
---
## 💡 技术要点
### 为什么服务器需要账号激活?
**服务器端状态管理**
```javascript
// 服务器端伪代码
class GameSession {
constructor(websocket) {
this.ws = websocket;
this.isActivated = false; // 初始未激活
this.roleInfo = null;
}
handleCommand(cmd, params) {
// 心跳消息总是处理
if (cmd === 'heart_beat') {
return this.sendHeartbeatResponse();
}
// 角色信息请求可以激活账号
if (cmd === 'role_getroleinfo') {
this.roleInfo = this.loadRoleInfo();
this.isActivated = true; // 激活账号
return this.sendRoleInfoResponse();
}
// 其他游戏命令需要账号已激活
if (!this.isActivated) {
console.log(`忽略命令 ${cmd}:账号未激活`);
return; // 不响应,不报错,直接忽略
}
// 正常处理游戏命令
this.handleGameCommand(cmd, params);
}
}
```
**设计目的**
1. **安全性**:防止未认证的连接执行游戏命令
2. **状态一致性**:确保服务器加载了完整的角色数据
3. **反作弊**:检测异常连接行为
---
### 为什么游戏功能模块不需要这个逻辑?
**原因**
1. 用户通常在多个页面之间切换
2. 账号可能已经在其他页面获取过角色信息
3. WebSocket连接可能是复用的
4. 即使是新连接,用户也会先浏览其他功能(如队伍、背包等)
5. 这些操作会自动触发角色信息获取
**批量自动化的特殊性**
1. 完全自动化,没有用户交互
2. 每次都是新连接
3. 直接执行特定命令
4. 更像"机器人"行为
**解决方案**
- 模拟正常游戏流程
- 先获取角色信息,激活账号
- 然后再执行游戏命令
---
## 🎯 总结
### 问题本质
- **批量自动化连接后直接查询车辆**
- **服务器需要先激活账号状态**
- **缺少初始化步骤,导致命令被忽略**
### 解决方案
- **在查询车辆前先获取角色信息**
- **模拟正常游戏流程**
- **让服务器"激活"账号状态**
### 预期结果
- ✅ 服务器正常响应 `car_getrolecar` 命令
- ✅ 查询车辆快速成功1-2秒
- ✅ 批量发车功能完美运行
---
## 🚀 下一步
1. **清除浏览器缓存**
2. **重启开发服务器**
3. **批量测试2-6个账号**
4. **观察日志,确认账号激活成功**
5. **验证查询车辆是否快速响应**
如果测试成功,说明问题已完美解决!🎉
如果仍然失败,我们有后备方案(增加更多初始化命令或增加延迟)。