kaiyu
2020-12-07 513d8719dd870fed4022dacc56be46353c33e7f4
更新Websocket以及rabbitMQ关闭逻辑
4 files modified
18 ■■■■ changed files
src/main/java/com/moral/controller/ScreenController.java 4 ●●● patch | view | raw | blame | history
src/main/java/com/moral/util/RabbitMQUtils.java 4 ●●●● patch | view | raw | blame | history
src/main/java/com/moral/webSocketServer/BSAQIWebSocketServer.java 5 ●●●●● patch | view | raw | blame | history
src/main/java/com/moral/webSocketServer/BSWebsocketServer.java 5 ●●●●● patch | view | raw | blame | history
src/main/java/com/moral/controller/ScreenController.java
@@ -727,7 +727,6 @@
             */
            /*改动范围start-------------------------------------------------------------------------*/
            list.remove(0);
            if (list.size() == 23) {
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd");
                //获取全格式时间yyyy-MM-dd HH:mm:ss
@@ -745,9 +744,8 @@
                    datas.put("time",time1);
                    list.add(datas);
                }
            }
            /*改动范围end-------------------------------------------------------------------------*/
            /*改动范围end-------------------------------------------------------------------------*/
            for (Map<String, Object> map : list) {
                String time = map.get("time").toString();
src/main/java/com/moral/util/RabbitMQUtils.java
@@ -27,9 +27,9 @@
    public static void closeConnectionChannel(Connection connection, Channel channel){
        try{
            if(channel!=null)
            if(channel!=null&&channel.isOpen())
                channel.close();
            if(connection!=null)
            if(connection!=null&&connection.isOpen())
                connection.close();
        }catch (Exception e){
            e.printStackTrace();
src/main/java/com/moral/webSocketServer/BSAQIWebSocketServer.java
@@ -92,6 +92,7 @@
            channel.basicConsume(queue, false, new DefaultConsumer(channel) {
                @Override
                public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                    try{
                    //对从MQ中取出的数据做转换,并且发送风速到客户端
                    Map message = (Map) JSON.parse((String) JSON.parse(new String(body)));
                    Device device = deviceService.getDeviceByMac(mac,false);
@@ -102,6 +103,10 @@
                    if (!webSocketMap.containsKey(accountId)) {
                        RabbitMQUtils.closeConnectionChannel(connection, channel);
                    }
                    }catch (Exception e){
                        log.error(e.getMessage());
                        RabbitMQUtils.closeConnectionChannel(connection, channel);
                    }
                }
            });
        } catch (IOException e) {
src/main/java/com/moral/webSocketServer/BSWebsocketServer.java
@@ -110,6 +110,7 @@
            channel.basicConsume(queue, false, new DefaultConsumer(channel) {
                @Override
                public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                      try{
                    //对从MQ中取出的数据做转换,并且发送风速到客户端
                    Map message = (Map) JSON.parse((String) JSON.parse(new String(body)));
                    sendWindInfo(message);
@@ -125,6 +126,10 @@
                    if (!webSocketMap.containsKey(accountId)) {
                        RabbitMQUtils.closeConnectionChannel(connection, channel);
                    }
                      }catch (Exception e){
                          log.error(e.getMessage());
                          RabbitMQUtils.closeConnectionChannel(connection, channel);
                      }
                }
            });
        } catch (IOException e) {