384 lines
11 KiB
Markdown
384 lines
11 KiB
Markdown
# 问题修复 - 错误码2300070未加入俱乐部提示 v3.11.24
|
||
|
||
**版本**: v3.11.24
|
||
**日期**: 2025-10-08
|
||
**类型**: 问题修复 / 用户体验改进
|
||
|
||
## 问题描述
|
||
|
||
用户反馈在批量任务执行时,遇到以下错误:
|
||
|
||
```
|
||
俱乐部签到失败
|
||
服务器错误: 2300070 - 未知错误
|
||
|
||
发车失败
|
||
服务器错误: 2300070 - 未知错误
|
||
```
|
||
|
||
**实际情况**:该账号未加入俱乐部
|
||
|
||
**问题分析**:
|
||
- 俱乐部签到和发车功能都需要账号先加入俱乐部
|
||
- 服务器返回错误码 `2300070` 表示未加入俱乐部
|
||
- 但系统显示为"未知错误",用户无法了解真实原因
|
||
- 需要识别这个错误码并给出友好提示
|
||
|
||
## 错误码说明
|
||
|
||
### 2300070 错误码
|
||
|
||
**含义**: 账号未加入俱乐部
|
||
|
||
**影响范围**:
|
||
- ❌ 俱乐部签到 - 需要加入俱乐部
|
||
- ❌ 发车功能 - 需要加入俱乐部才能使用赛车
|
||
- ✅ 其他功能(每日修复、自动学习、领取奖励等)不受影响
|
||
|
||
**处理策略**:
|
||
- 识别错误码 2300070
|
||
- 显示友好的错误提示:"该账号未加入俱乐部"
|
||
- 标记为失败(因为无法完成操作)
|
||
- 停止继续尝试(避免重复失败)
|
||
|
||
## 解决方案
|
||
|
||
### 1. 俱乐部签到错误处理
|
||
|
||
在 `legionSignIn` 任务中添加对错误码 2300070 的识别:
|
||
|
||
```javascript
|
||
case 'legionSignIn':
|
||
// 俱乐部签到
|
||
return await executeSubTask(
|
||
tokenId,
|
||
'legion_signin',
|
||
'俱乐部签到',
|
||
async () => {
|
||
try {
|
||
const result = await client.sendWithPromise('legion_signin', {}, 5000)
|
||
return result
|
||
} catch (error) {
|
||
const errorMsg = error.message || String(error)
|
||
|
||
// 错误码 2300190 表示"今日已签到",不应视为错误
|
||
if (errorMsg.includes('2300190')) {
|
||
console.log('ℹ️ 俱乐部今日已签到,跳过')
|
||
return { alreadySignedIn: true }
|
||
}
|
||
|
||
// ✅ 新增:错误码 2300070 表示"未加入俱乐部"
|
||
if (errorMsg.includes('2300070')) {
|
||
console.log('⚠️ 俱乐部签到失败:该账号未加入俱乐部')
|
||
throw new Error('该账号未加入俱乐部,无法签到')
|
||
}
|
||
|
||
// 超时错误:提示用户检查游戏内实际状态
|
||
if (errorMsg.includes('请求超时') || errorMsg.includes('timeout')) {
|
||
console.warn('⚠️ 俱乐部签到超时,请检查游戏内是否已签到')
|
||
return { timeout: true, message: '超时(可能已成功,请检查游戏内状态)' }
|
||
}
|
||
|
||
// 其他错误正常抛出
|
||
throw error
|
||
}
|
||
},
|
||
false
|
||
)
|
||
```
|
||
|
||
### 2. 发车功能 - 查询车辆错误处理
|
||
|
||
在 `queryClubCars` 函数中添加对错误码 2300070 的识别:
|
||
|
||
```javascript
|
||
const queryClubCars = async () => {
|
||
console.log(`🚗 [${tokenId}] 开始查询俱乐部车辆...`)
|
||
try {
|
||
const response = await tokenStore.sendMessageAsync(tokenId, 'car_getrolecar', {}, 5000)
|
||
|
||
if (!response || !response.roleCar) {
|
||
throw new Error('查询车辆失败:未返回车辆数据')
|
||
}
|
||
|
||
const carDataMap = response.roleCar.carDataMap || {}
|
||
const carIds = Object.keys(carDataMap).sort()
|
||
|
||
return { carDataMap, carIds }
|
||
} catch (error) {
|
||
const errorMsg = error.message || String(error)
|
||
// ✅ 新增:检查是否是未加入俱乐部的错误(200400 或 2300070)
|
||
if (errorMsg.includes('200400') || errorMsg.includes('2300070')) {
|
||
throw new Error('该账号未加入俱乐部或没有赛车权限')
|
||
}
|
||
throw error
|
||
}
|
||
}
|
||
```
|
||
|
||
### 3. 发车功能 - 发送车辆错误处理
|
||
|
||
在发送车辆的错误处理中添加对错误码 2300070 的识别:
|
||
|
||
```javascript
|
||
} catch (error) {
|
||
const errorMsg = error.message || String(error)
|
||
|
||
// 区分不同的错误类型
|
||
if (errorMsg.includes('12000050')) {
|
||
console.log(`⚠️ [${tokenId}] 车辆 ${carId} 发送失败: 今日发车次数已达上限(服务器端限制)`)
|
||
localStorage.setItem(dailySendKey, '4')
|
||
dailySendCount = 4
|
||
break
|
||
} else if (errorMsg.includes('200020')) {
|
||
console.log(`⚠️ [${tokenId}] 车辆 ${carId} 处于发送冷却期`)
|
||
} else if (errorMsg.includes('200350')) {
|
||
console.log(`⚠️ [${tokenId}] 车辆 ${carId} 发送失败: 非发车时间(6:00-20:00)或已发车后收车`)
|
||
sendSkipCount++
|
||
break
|
||
} else if (errorMsg.includes('2300070')) {
|
||
// ✅ 新增:错误码2300070:未加入俱乐部
|
||
console.log(`⚠️ [${tokenId}] 发车失败: 该账号未加入俱乐部`)
|
||
sendSkipCount++
|
||
break
|
||
} else {
|
||
console.error(`❌ [${tokenId}] 发送车辆失败: ${carId} - ${errorMsg}`)
|
||
}
|
||
}
|
||
```
|
||
|
||
## 修改文件
|
||
|
||
### src/stores/batchTaskStore.js
|
||
|
||
**修改位置**:
|
||
1. **line 1050-1053**: `legionSignIn` 任务 - 添加 2300070 错误识别
|
||
2. **line 1258**: `queryClubCars` 函数 - 添加 2300070 错误识别
|
||
3. **line 1560-1566**: 发送车辆错误处理 - 添加 2300070 错误识别
|
||
|
||
## 用户体验改进
|
||
|
||
### 修改前
|
||
|
||
```
|
||
执行进度详情
|
||
┌─────────────────────────────┐
|
||
│ ❌ 俱乐部签到 │
|
||
│ 服务器错误: 2300070 - │
|
||
│ 未知错误 │
|
||
├─────────────────────────────┤
|
||
│ ❌ 发车 │
|
||
│ 服务器错误: 2300070 - │
|
||
│ 未知错误 │
|
||
└─────────────────────────────┘
|
||
|
||
问题:
|
||
- ❌ "未知错误" 没有提供有用信息
|
||
- ❌ 用户不知道是什么原因
|
||
- ❌ 用户不知道如何解决
|
||
```
|
||
|
||
### 修改后
|
||
|
||
```
|
||
执行进度详情
|
||
┌─────────────────────────────┐
|
||
│ ❌ 俱乐部签到 │
|
||
│ 该账号未加入俱乐部, │
|
||
│ 无法签到 │
|
||
├─────────────────────────────┤
|
||
│ ❌ 发车 │
|
||
│ 该账号未加入俱乐部或 │
|
||
│ 没有赛车权限 │
|
||
└─────────────────────────────┘
|
||
|
||
改进:
|
||
- ✅ 明确说明失败原因
|
||
- ✅ 用户知道是未加入俱乐部导致
|
||
- ✅ 用户知道需要先加入俱乐部
|
||
```
|
||
|
||
### 控制台日志
|
||
|
||
**修改前**:
|
||
```
|
||
❌ [10684...] 俱乐部签到失败: 服务器错误: 2300070 - 未知错误
|
||
❌ [10684...] 发送车辆失败: 1 - 服务器错误: 2300070 - 未知错误
|
||
```
|
||
|
||
**修改后**:
|
||
```
|
||
⚠️ 俱乐部签到失败:该账号未加入俱乐部
|
||
⚠️ [10684...] 发车失败: 该账号未加入俱乐部
|
||
```
|
||
|
||
## 相关错误码对比
|
||
|
||
### 俱乐部相关错误码
|
||
|
||
| 错误码 | 含义 | 处理方式 |
|
||
|--------|------|---------|
|
||
| `2300070` | 未加入俱乐部 | ❌ 失败,提示加入俱乐部 |
|
||
| `2300190` | 今日已签到 | ✅ 跳过,视为成功 |
|
||
| `200400` | 未加入俱乐部或无权限 | ❌ 失败,提示加入俱乐部 |
|
||
|
||
### 发车相关错误码
|
||
|
||
| 错误码 | 含义 | 处理方式 |
|
||
|--------|------|---------|
|
||
| `2300070` | 未加入俱乐部 | ⚠️ 跳过,停止继续尝试 |
|
||
| `200350` | 非发车时间或已收车 | ⚠️ 跳过,停止继续尝试 |
|
||
| `200020` | 发送冷却期 | ⚠️ 跳过,继续下一辆 |
|
||
| `12000050` | 今日发车已达上限 | ⚠️ 跳过,停止继续尝试 |
|
||
| `200400` | 未加入俱乐部或无权限 | ❌ 失败,停止执行 |
|
||
|
||
## 处理策略差异
|
||
|
||
### 俱乐部签到
|
||
|
||
```javascript
|
||
if (errorMsg.includes('2300070')) {
|
||
// 抛出错误,标记任务为失败
|
||
throw new Error('该账号未加入俱乐部,无法签到')
|
||
}
|
||
```
|
||
|
||
**原因**:
|
||
- 签到是单一操作
|
||
- 失败就是失败,没有备选方案
|
||
- 需要让用户知道明确的失败状态
|
||
|
||
### 发车功能
|
||
|
||
```javascript
|
||
} else if (errorMsg.includes('2300070')) {
|
||
// 不抛出错误,计入 sendSkipCount
|
||
console.log(`⚠️ [${tokenId}] 发车失败: 该账号未加入俱乐部`)
|
||
sendSkipCount++
|
||
break
|
||
}
|
||
```
|
||
|
||
**原因**:
|
||
- 发车是批量操作(可能尝试多辆车)
|
||
- 未加入俱乐部意味着所有车辆都无法发送
|
||
- 使用 `break` 立即停止,避免重复失败
|
||
- 计入 `sendSkipCount` 而非失败计数
|
||
- 最终任务仍会失败(因为 `sendSuccessCount === 0`)
|
||
|
||
## 技术要点
|
||
|
||
### 错误识别优先级
|
||
|
||
在错误处理中,按照以下优先级检查:
|
||
|
||
1. **特殊成功状态**(如 2300190 已签到)→ 返回成功
|
||
2. **可识别的错误码**(如 2300070 未加入)→ 友好提示
|
||
3. **超时错误** → 特殊处理(可能已成功)
|
||
4. **其他错误** → 原样抛出
|
||
|
||
```javascript
|
||
if (errorMsg.includes('2300190')) {
|
||
return { alreadySignedIn: true } // 1. 特殊成功
|
||
}
|
||
if (errorMsg.includes('2300070')) {
|
||
throw new Error('友好提示') // 2. 可识别错误
|
||
}
|
||
if (errorMsg.includes('timeout')) {
|
||
return { timeout: true } // 3. 超时
|
||
}
|
||
throw error // 4. 其他错误
|
||
```
|
||
|
||
### 错误消息转换
|
||
|
||
```javascript
|
||
// 系统错误(不友好)
|
||
服务器错误: 2300070 - 未知错误
|
||
|
||
// 转换后(友好)
|
||
该账号未加入俱乐部,无法签到
|
||
```
|
||
|
||
**转换方法**:
|
||
```javascript
|
||
if (errorMsg.includes('2300070')) {
|
||
throw new Error('该账号未加入俱乐部,无法签到')
|
||
}
|
||
```
|
||
|
||
## 测试验证
|
||
|
||
### 测试场景
|
||
|
||
1. ✅ **未加入俱乐部**
|
||
- 俱乐部签到 → 显示"该账号未加入俱乐部,无法签到"
|
||
- 发车 → 显示"该账号未加入俱乐部或没有赛车权限"
|
||
|
||
2. ✅ **已加入俱乐部**
|
||
- 俱乐部签到 → 正常签到或显示"今日已签到"
|
||
- 发车 → 正常发车或其他错误提示
|
||
|
||
3. ✅ **其他错误**
|
||
- 超时 → "超时(可能已成功,请检查游戏内状态)"
|
||
- 未知错误 → 显示原始错误信息
|
||
|
||
### 预期行为
|
||
|
||
**未加入俱乐部的账号**:
|
||
```
|
||
总任务: 7
|
||
成功: 5(每日修复、自动学习、领取奖励、加钟、爬塔)
|
||
失败: 2(俱乐部签到、发车)
|
||
|
||
失败任务详情:
|
||
- ❌ 俱乐部签到: 该账号未加入俱乐部,无法签到
|
||
- ❌ 发车: 该账号未加入俱乐部或没有赛车权限
|
||
```
|
||
|
||
## 用户指南
|
||
|
||
### 如何解决此问题?
|
||
|
||
当看到"该账号未加入俱乐部"提示时:
|
||
|
||
1. **进入游戏**
|
||
2. **加入俱乐部**:
|
||
- 点击游戏内的"俱乐部"功能
|
||
- 搜索并申请加入一个俱乐部
|
||
- 或创建自己的俱乐部
|
||
3. **等待审核通过**(如果是申请加入)
|
||
4. **重新执行任务**
|
||
|
||
**注意**:
|
||
- 俱乐部签到和发车功能必须先加入俱乐部
|
||
- 其他任务(每日修复、学习、领奖等)不受影响
|
||
- 如果不需要这两个功能,可以使用"快速套餐"模板
|
||
|
||
## 相关版本
|
||
|
||
- **v3.11.1**: 修复俱乐部签到错误码 2300190
|
||
- **v3.11.15**: 修复俱乐部签到超时误判
|
||
- **v3.11.20**: 修复发车错误码 200350
|
||
- **v3.11.24**: 添加错误码 2300070 识别(本版本)
|
||
|
||
## 总结
|
||
|
||
**核心改进**:
|
||
- 🔍 识别错误码 2300070(未加入俱乐部)
|
||
- 💬 提供友好的错误提示
|
||
- 📊 在三个位置添加错误处理(俱乐部签到、查询车辆、发送车辆)
|
||
- ✅ 帮助用户快速定位问题原因
|
||
|
||
**用户获益**:
|
||
- ✅ 明确知道失败原因
|
||
- ✅ 知道如何解决问题
|
||
- ✅ 减少疑惑和困扰
|
||
- ✅ 提升整体体验
|
||
|
||
---
|
||
|
||
**状态**: ✅ 已完成
|
||
**版本**: v3.11.24
|
||
|