jinpengyong
2021-07-22 6278a11e191892ae672eba0dce6d8990283327a6
screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
@@ -2,6 +2,7 @@
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;
@@ -30,22 +31,25 @@
    //线程安全集合,用于存放server对象
    public static CopyOnWriteArraySet<SingleDeviceServer> sockets = new CopyOnWriteArraySet<>();
    public static RedisTemplate redisTemplate;
    private Session session;
    private String mac;
    public static RedisTemplate redisTemplate;
    private Map<String, Device> devicesInfo;
    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() {
@@ -63,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);
            // }
        }
    }
}