Todo: 修改因exe_token错误导致的不断重连问题
Todo: 修改打包中.bat打包文件与测试打包脚本不一致问题 New: 新增installer安装包环境搭建数据
This commit is contained in:
@@ -29,6 +29,7 @@ class BackendClient:
|
||||
self.error_callback: Optional[Callable] = None
|
||||
self.login_callback: Optional[Callable] = None # 新增:平台登录(下发cookies)回调
|
||||
self.success_callback: Optional[Callable] = None # 新增:后端连接成功回调
|
||||
self.token_error_callback: Optional[Callable] = None # 新增:token错误回调
|
||||
|
||||
self.is_connected = False
|
||||
|
||||
@@ -261,7 +262,8 @@ class BackendClient:
|
||||
close: Callable = None,
|
||||
error: Callable = None,
|
||||
login: Callable = None,
|
||||
success: Callable = None):
|
||||
success: Callable = None,
|
||||
token_error: Callable = None):
|
||||
"""设置各种消息类型的回调函数"""
|
||||
if store_list:
|
||||
self.store_list_callback = store_list
|
||||
@@ -279,6 +281,8 @@ class BackendClient:
|
||||
self.login_callback = login
|
||||
if success:
|
||||
self.success_callback = success
|
||||
if token_error:
|
||||
self.token_error_callback = token_error
|
||||
|
||||
def on_connected(self):
|
||||
"""连接成功时的处理"""
|
||||
@@ -338,7 +342,7 @@ class BackendClient:
|
||||
active_store_id = None
|
||||
try:
|
||||
from Utils.JD.JdUtils import WebsocketManager as JdManager
|
||||
from Utils.Dy.DyUtils import WebsocketManager as DyManager
|
||||
from Utils.Dy.DyUtils import DouYinWebsocketManager as DyManager
|
||||
from Utils.Pdd.PddUtils import WebsocketManager as PddManager
|
||||
|
||||
# 检查各平台是否有活跃连接
|
||||
@@ -429,6 +433,8 @@ class BackendClient:
|
||||
self._handle_login(message)
|
||||
elif msg_type == 'error':
|
||||
self._handle_error_message(message)
|
||||
elif msg_type == 'error_token':
|
||||
self._handle_token_error(message)
|
||||
elif msg_type == 'staff_list':
|
||||
self._handle_staff_list(message)
|
||||
else:
|
||||
@@ -1163,10 +1169,35 @@ class BackendClient:
|
||||
def _handle_error_message(self, message: Dict[str, Any]):
|
||||
"""处理错误消息"""
|
||||
error_msg = message.get('error', '未知错误')
|
||||
content = message.get('content', '')
|
||||
|
||||
# 检查是否为token错误(无论type是error还是error_token)
|
||||
if content == "无效的exe_token" or "无效的exe_token" in content:
|
||||
print(f"[错误] 检测到token错误: {content}")
|
||||
self._handle_token_error(message)
|
||||
return
|
||||
|
||||
print(f"后端连接错误: {error_msg}")
|
||||
if self.error_callback:
|
||||
self.error_callback(error_msg, message)
|
||||
|
||||
def _handle_token_error(self, message: Dict[str, Any]):
|
||||
"""处理token错误消息 - 无效token时停止重连并显示错误"""
|
||||
error_content = message.get('content', '无效的exe_token')
|
||||
print(f"[错误] Token验证失败: {error_content}")
|
||||
|
||||
# 停止重连机制
|
||||
self.should_stop = True
|
||||
self.is_reconnecting = False
|
||||
|
||||
# 触发token错误回调
|
||||
if self.token_error_callback:
|
||||
self.token_error_callback(error_content)
|
||||
|
||||
# 主动关闭连接
|
||||
if self.websocket:
|
||||
asyncio.run_coroutine_threadsafe(self.websocket.close(), self.loop)
|
||||
|
||||
def _handle_staff_list(self, message: Dict[str, Any]):
|
||||
"""处理客服列表更新消息"""
|
||||
staff_list = message.get('data', {}).get('staff_list', [])
|
||||
|
||||
Reference in New Issue
Block a user