From 4f86dc69d3e392679fab9deddf7a6903663dbc71 Mon Sep 17 00:00:00 2001
From: whycxzp <glperry@163.com>
Date: 星期二, 25 三月 2025 21:30:14 +0800
Subject: [PATCH] ws

---
 src/main/java/com/whyc/webSocket/PowerAlarmSocket.java |  107 ++++++++++++++++++++++++++
 src/main/java/com/whyc/webSocket/BattAlarmSocket.java  |  109 +++++++++++++++++++++++++++
 2 files changed, 216 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/whyc/webSocket/BattAlarmSocket.java b/src/main/java/com/whyc/webSocket/BattAlarmSocket.java
new file mode 100644
index 0000000..561e2ce
--- /dev/null
+++ b/src/main/java/com/whyc/webSocket/BattAlarmSocket.java
@@ -0,0 +1,109 @@
+package com.whyc.webSocket;
+
+import com.whyc.config.WebSocketConfig;
+import com.whyc.dto.DevA200AlarmDto;
+import com.whyc.dto.PageAlarm;
+import com.whyc.dto.Response;
+import com.whyc.pojo.db_user.UserInf;
+import com.whyc.service.BattAlarmService;
+import com.whyc.service.DevLithiumAlarmDataService;
+import com.whyc.util.ActionUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import javax.servlet.http.HttpSession;
+import javax.websocket.*;
+import javax.websocket.server.ServerEndpoint;
+import java.util.HashMap;
+import java.util.Map;
+
+
+/**
+ * 鐢垫睜鍛婅
+ */
+@Component
+@ServerEndpoint(value = "/battAlarm/getPage",encoders = WebSocketEncoder.class,configurator = WebSocketConfig.class)
+public class BattAlarmSocket {
+    private Session session;
+
+    private Thread thread;
+
+    private static BattAlarmService service;
+
+    private HttpSession httpSession;
+
+    private volatile boolean runFlag = true;
+
+    private volatile Map<String, Thread> threadMap = new HashMap<>();
+
+    private volatile Map<Long,Boolean> threadFlagMap = new HashMap<>();
+
+    @Autowired
+    public void setService(BattAlarmService service) {
+        BattAlarmSocket.service = service;
+    }
+
+    @OnOpen
+    public void onOpen(Session session, EndpointConfig config) {
+        this.session = session;
+        this.httpSession = (HttpSession) config.getUserProperties().get("httpSession");
+    }
+    @OnMessage
+    public void onMessage(Session session, String message) {
+        PageAlarm dto = ActionUtil.getGson("yyyy-MM-dd HH:mm:ss").fromJson(message, PageAlarm.class);
+        thread = new Thread("Thread_BattAlarmSocket") {
+            @Override
+            public void run() {
+                while (runFlag && !isInterrupted()) {
+                    Thread thread = currentThread();
+                    threadFlagMap.put(thread.getId(), true);
+                    try {
+                        Response res=service.getPage(dto.getAlmLevel(),dto.getStartTime(),dto.getEndTime(),
+                                dto.getPageNum(),dto.getPageSize());
+                        if (session.isOpen()) {
+                            //鎺ㄩ�佷俊鎭�
+                            synchronized (session) {
+                                session.getBasicRemote().sendObject(res);
+                            }
+                            threadFlagMap.put(thread.getId(), false);
+                        }
+                        sleep(4000);
+                    } catch (Exception e) {
+                        interrupt();
+                    }
+                }
+            }
+        };
+        thread.start();
+        threadFlagMap.put(thread.getId(),true);
+        //鍋滄鑰佺殑socket绾跨▼
+        Thread threadBefore = threadMap.get(session.getId());
+        if(threadBefore !=null && threadBefore.isAlive()){
+            while (threadFlagMap.get(threadBefore.getId())){
+            }
+            threadBefore.interrupt();
+        }
+        //灏嗙嚎绋嬪瓨鍌�,渚夸簬璋冪敤瀹氫綅
+        threadMap.put(session.getId(), this.thread);
+    }
+
+
+    @OnClose
+    public void onClose(CloseReason closeReason){
+        System.err.println("closeReason = " + closeReason);
+        runFlag = false;
+        if (thread != null && thread.isAlive()) {
+            thread.interrupt();
+        }
+        threadMap.remove(session.getId());
+    }
+
+    @OnError
+    public void onError(Throwable error) {
+        error.printStackTrace();
+        if (thread != null && thread.isAlive()) {
+            thread.interrupt();
+        }
+        threadMap.remove(session.getId());
+    }
+}
\ No newline at end of file
diff --git a/src/main/java/com/whyc/webSocket/PowerAlarmSocket.java b/src/main/java/com/whyc/webSocket/PowerAlarmSocket.java
new file mode 100644
index 0000000..389e98f
--- /dev/null
+++ b/src/main/java/com/whyc/webSocket/PowerAlarmSocket.java
@@ -0,0 +1,107 @@
+package com.whyc.webSocket;
+
+import com.whyc.config.WebSocketConfig;
+import com.whyc.dto.PageAlarm;
+import com.whyc.dto.Response;
+import com.whyc.service.BattAlarmService;
+import com.whyc.service.PowerAlarmService;
+import com.whyc.util.ActionUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import javax.servlet.http.HttpSession;
+import javax.websocket.*;
+import javax.websocket.server.ServerEndpoint;
+import java.util.HashMap;
+import java.util.Map;
+
+
+/**
+ * 鐢垫簮鍛婅
+ */
+@Component
+@ServerEndpoint(value = "/powerAlarm/getPage",encoders = WebSocketEncoder.class,configurator = WebSocketConfig.class)
+public class PowerAlarmSocket {
+    private Session session;
+
+    private Thread thread;
+
+    private static PowerAlarmService service;
+
+    private HttpSession httpSession;
+
+    private volatile boolean runFlag = true;
+
+    private volatile Map<String, Thread> threadMap = new HashMap<>();
+
+    private volatile Map<Long,Boolean> threadFlagMap = new HashMap<>();
+
+    @Autowired
+    public void setService(PowerAlarmService service) {
+        PowerAlarmSocket.service = service;
+    }
+
+    @OnOpen
+    public void onOpen(Session session, EndpointConfig config) {
+        this.session = session;
+        this.httpSession = (HttpSession) config.getUserProperties().get("httpSession");
+    }
+    @OnMessage
+    public void onMessage(Session session, String message) {
+        PageAlarm dto = ActionUtil.getGson("yyyy-MM-dd HH:mm:ss").fromJson(message, PageAlarm.class);
+        thread = new Thread("Thread_BattAlarmSocket") {
+            @Override
+            public void run() {
+                while (runFlag && !isInterrupted()) {
+                    Thread thread = currentThread();
+                    threadFlagMap.put(thread.getId(), true);
+                    try {
+                        Response res=service.getPage(dto.getAlmLevel(),dto.getStartTime(),dto.getEndTime(),
+                                dto.getPageNum(),dto.getPageSize());
+                        if (session.isOpen()) {
+                            //鎺ㄩ�佷俊鎭�
+                            synchronized (session) {
+                                session.getBasicRemote().sendObject(res);
+                            }
+                            threadFlagMap.put(thread.getId(), false);
+                        }
+                        sleep(4000);
+                    } catch (Exception e) {
+                        interrupt();
+                    }
+                }
+            }
+        };
+        thread.start();
+        threadFlagMap.put(thread.getId(),true);
+        //鍋滄鑰佺殑socket绾跨▼
+        Thread threadBefore = threadMap.get(session.getId());
+        if(threadBefore !=null && threadBefore.isAlive()){
+            while (threadFlagMap.get(threadBefore.getId())){
+            }
+            threadBefore.interrupt();
+        }
+        //灏嗙嚎绋嬪瓨鍌�,渚夸簬璋冪敤瀹氫綅
+        threadMap.put(session.getId(), this.thread);
+    }
+
+
+    @OnClose
+    public void onClose(CloseReason closeReason){
+        System.err.println("closeReason = " + closeReason);
+        runFlag = false;
+        if (thread != null && thread.isAlive()) {
+            thread.interrupt();
+        }
+        threadMap.remove(session.getId());
+    }
+
+    @OnError
+    public void onError(Throwable error) {
+        error.printStackTrace();
+        if (thread != null && thread.isAlive()) {
+            thread.interrupt();
+        }
+        threadMap.remove(session.getId());
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.1