From 3dbe2c21c05072cdab5a7f75a0bd154bd9207552 Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Wed, 14 Jul 2021 13:09:12 +0800
Subject: [PATCH] screen-manage                  实时数据message,添加time,datatime,time1等测试数据

---
 screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java |   24 +++++++++++++++++++-----
 1 files changed, 19 insertions(+), 5 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java b/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
index 107357d..748efc3 100644
--- a/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
+++ b/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
@@ -1,11 +1,19 @@
 package com.moral.api.websocket;
 
+import com.moral.api.entity.Device;
+import com.moral.api.entity.Sensor;
+import com.moral.api.entity.UnitConversion;
+import com.moral.constant.RedisConstants;
+import lombok.Data;
+import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Component;
 import org.springframework.web.bind.annotation.PathVariable;
 
 import javax.websocket.*;
 import javax.websocket.server.PathParam;
 import javax.websocket.server.ServerEndpoint;
+import java.util.List;
+import java.util.Map;
 import java.util.concurrent.CopyOnWriteArraySet;
 
 /**
@@ -17,24 +25,31 @@
  **/
 @ServerEndpoint("/singleDevice/{mac}")
 @Component
+@Data
 public class SingleDeviceServer {
 
     //���������������������������������server������
     public static CopyOnWriteArraySet<SingleDeviceServer> sockets = new CopyOnWriteArraySet<>();
 
+    public static RedisTemplate redisTemplate;
+
     private Session session;
 
     private String mac;
 
+    private Map<String, Device> devicesInfo;
 
+    private List<UnitConversion> unitConversions;
 
     @OnOpen
     public void onOpen(Session session, @PathParam("mac") String mac) throws Exception {
         this.session = session;
         this.mac = mac;
+        this.devicesInfo = redisTemplate.opsForHash().entries(RedisConstants.DEVICE_INFO);
+        this.unitConversions = redisTemplate.opsForList().range(RedisConstants.UNIT_CONVERSION, 0, -1);
         sockets.add(this);
         System.out.println(mac);
-    }
+}
 
     @OnClose
     public void onClose() {
@@ -52,11 +67,10 @@
 
     public void sendMessage(String message) throws Exception {
         if (this.session.isOpen()) {
-            synchronized (session) {
-                this.session.getBasicRemote().sendText(message);
-            }
+            //  synchronized (session) {
+            this.session.getBasicRemote().sendText(message);
+            // }
         }
     }
-
 
 }

--
Gitblit v1.8.0