From 016aa105789fca71e86cdbb0d26a181812f200f9 Mon Sep 17 00:00:00 2001 From: liusuyi <1951119284@qq.com> Date: 星期三, 10 七月 2024 15:33:36 +0800 Subject: [PATCH] 优化:流媒体同步任务 --- ard-work/src/main/java/com/ruoyi/utils/websocket/service/ChatServerEndpoint.java | 31 +++++++++++++++++++++++++++---- 1 files changed, 27 insertions(+), 4 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/utils/websocket/service/ChatServerEndpoint.java b/ard-work/src/main/java/com/ruoyi/utils/websocket/service/ChatServerEndpoint.java index 5b1dcb4..c988db1 100644 --- a/ard-work/src/main/java/com/ruoyi/utils/websocket/service/ChatServerEndpoint.java +++ b/ard-work/src/main/java/com/ruoyi/utils/websocket/service/ChatServerEndpoint.java @@ -1,6 +1,8 @@ package com.ruoyi.utils.websocket.service; +import com.alibaba.fastjson2.JSONObject; import com.ruoyi.app.position.service.impl.AppPositionPushService; +import com.ruoyi.call.dto.CallMessage; import com.ruoyi.utils.websocket.util.WebSocketUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Component; @@ -9,6 +11,11 @@ import javax.websocket.server.PathParam; import javax.websocket.server.ServerEndpoint; import java.io.IOException; +import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static com.ruoyi.utils.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS; /** * @ClassName ChatServerEndpoint @@ -33,11 +40,27 @@ @OnMessage public void onMessage(@PathParam("userId") String userId, String message) { log.info("鏀跺埌娑堟伅锛�" + message); - Session session = WebSocketUtils.ONLINE_USER_SESSIONS.get(userId); - WebSocketUtils.sendMessage(session, message); - //sendMessageAll("鐢ㄦ埛[" + userid + "] : " + message); +// Session session = WebSocketUtils.ONLINE_USER_SESSIONS.get(userId); +// WebSocketUtils.sendMessage(session, message); + Map<String, Object> messageMap = JSONObject.parseObject(message, Map.class); + if (((String) messageMap.get("type")).equals("callMessage")) { + String msg = (String) messageMap.get("message"); + CallMessage callMessage = JSONObject.parseObject(msg, CallMessage.class); + if (callMessage != null && callMessage.getType().equals(0)) { + String regex = "^" + Pattern.quote(callMessage.getTargetId()) + "_\\d+$"; + Pattern pattern = Pattern.compile(regex); + ONLINE_USER_SESSIONS.entrySet().stream() + .filter(entry -> { + Matcher matcher = pattern.matcher(entry.getKey()); + return matcher.matches(); + }) + .map(Map.Entry::getValue) + .forEach(session -> WebSocketUtils.sendMessage(session, message)); + } + + } // 鏍规嵁鐢ㄦ埛鏂扮殑棰戠巼閲嶆柊璋冩暣瀹氭椂浠诲姟 - AppPositionPushService.messageHandler(userId,message); + AppPositionPushService.messageHandler(userId, message); } @OnClose -- Gitblit v1.9.3