From e4ebf74baef4faab3fa794c042e2921437525e6e Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Thu, 12 Aug 2021 10:40:52 +0800
Subject: [PATCH] update
---
screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java | 26 +++++++++++++++++++++-----
1 files changed, 21 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 fa1a3b3..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,22 +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() {
@@ -50,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