From 072a5438e872036ed4fa7a7ab0a932e86823e60e Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 03 四月 2024 13:56:17 +0800
Subject: [PATCH] #
---
zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapWebsocket.java | 54 ++++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 42 insertions(+), 12 deletions(-)
diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapWebsocket.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapWebsocket.java
index 49dad31..fcf520f 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapWebsocket.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapWebsocket.java
@@ -3,35 +3,65 @@
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
-import javax.websocket.OnClose;
-import javax.websocket.OnMessage;
-import javax.websocket.OnOpen;
-import javax.websocket.Session;
+import javax.websocket.*;
import javax.websocket.server.ServerEndpoint;
+import java.util.concurrent.ConcurrentHashMap;
@Slf4j
@Component
-@ServerEndpoint(value = "/map/websocket")
+@ServerEndpoint(value = "/ws/map/websocket")
public class MapWebsocket {
- private Session session;
- private String sessionId;
+ private static final ConcurrentHashMap<String, Session> sessions = new ConcurrentHashMap<>();
@OnOpen
public void onOpen(Session session) {
- this.session = session;
- this.sessionId = session.getId();
- log.info("{} connected", this.sessionId);
+ sessions.put(session.getId(), session);
+ log.info("Opened new session in instance " + session.getId());
}
@OnMessage
public void onMessage(String message, Session session) {
- log.info("{} sendMsg:{}", this.sessionId, message);
+ log.info("Received WebSocket message: {}", message);
}
@OnClose
public void onClose(Session session) {
- log.info("{} closed", this.sessionId);
+ sessions.remove(session.getId());
+ log.info("Closed WebSocket session: {}", session.getId());
+ }
+
+ @OnError
+ public void onError(Session session, Throwable error) {
+ error.printStackTrace();
+ log.error("Error in WebSocket session: {}", session.getId(), error);
+ try {
+ session.close();
+ } catch (Exception e) {
+ log.error("Error closing session: {}", session.getId(), e);
+ } finally {
+ sessions.remove(session.getId());
+ }
+ }
+
+ public static void sendMessage(Session session, String message) {
+ if(session.isOpen()){
+ try {
+ session.getBasicRemote().sendText(message);
+ } catch (Exception e) {
+ log.error("Failed to send message to session: {}", session.getId(), e);
+ }
+ }
+ }
+
+ public static void broadcast(String message) {
+ sessions.forEach((id, session) -> {
+ try {
+ session.getBasicRemote().sendText(message);
+ } catch (Exception e) {
+ log.error("Failed to send message to session: {}", id, e);
+ }
+ });
}
}
--
Gitblit v1.9.1