From 50718b289ef39ef027c4959cc835679ebadd84bb Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期五, 10 十一月 2023 17:32:05 +0800
Subject: [PATCH] 车辆电磁锁订阅

---
 ard-work/src/main/java/com/ruoyi/sy/service/ArdSyCarRtuService.java          |    3 
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdSyCarRtu.java                  |    4 
 ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnce.java                    |   27 ++++++++
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarRtuServiceImpl.java |   12 +++
 ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttConsumerCallback.java        |    3 -
 ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnceCallback.java            |   98 ++++++++++++++++++++++++++++++++
 6 files changed, 138 insertions(+), 9 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdSyCarRtu.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdSyCarRtu.java
index b02fa9b..7487879 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdSyCarRtu.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdSyCarRtu.java
@@ -10,6 +10,6 @@
 public class ArdSyCarRtu {
     private String id;
     private String carId;
-    private String topicSubscribe;
-    private String topicPublish;
+    private String topicSubscribe; //璁㈤槄
+    private String topicPublish; //鍙戝竷
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/ArdSyCarRtuService.java b/ard-work/src/main/java/com/ruoyi/sy/service/ArdSyCarRtuService.java
index 0fd028f..6b7f196 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/ArdSyCarRtuService.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/ArdSyCarRtuService.java
@@ -9,7 +9,8 @@
  */
 public interface ArdSyCarRtuService {
 
-    List<ArdSyCarRtu> allCarTopic();
+    String[] allCarTopic();
+    List<ArdSyCarRtu> allCarTopicList();
 
     ArdSyCarRtu one(String carId);
 
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarRtuServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarRtuServiceImpl.java
index 8f94e14..025ca99 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarRtuServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarRtuServiceImpl.java
@@ -22,7 +22,17 @@
     private ArdSyCarRtuMapper ardSyCarRtuMapper;
 
     @Override
-    public List<ArdSyCarRtu> allCarTopic() {
+    public String[] allCarTopic() {
+        List<ArdSyCarRtu> carRtus = ardSyCarRtuMapper.selectList(null);
+        List<String> list = new ArrayList<>();
+        for (int i = 0; i < carRtus.size(); i++) {
+            list.add(carRtus.get(i).getTopicPublish());
+        }
+        return list.toArray(new String[list.size()]);
+    }
+
+    @Override
+    public List<ArdSyCarRtu> allCarTopicList() {
         return ardSyCarRtuMapper.selectList(null);
     }
 
diff --git a/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttConsumerCallback.java b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttConsumerCallback.java
index f25b749..29965fa 100644
--- a/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttConsumerCallback.java
+++ b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttConsumerCallback.java
@@ -91,9 +91,6 @@
                 ArdRadarService ardRadarService = SpringUtils.getBean(ArdRadarService.class);
                 ardRadarService.forceGuide(new String(message.getPayload(), StandardCharsets.UTF_8));
             }
-            if(topic.contains("/p")){
-                System.out.println("杞﹁締閿佷俊鎭細"+new String(message.getPayload(), StandardCharsets.UTF_8));
-            }
         } catch (Exception e) {
             log.debug("澶勭悊mqtt娑堟伅寮傚父:" + e);
         }
diff --git a/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnce.java b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnce.java
index b07a18b..3b88ad2 100644
--- a/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnce.java
+++ b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnce.java
@@ -5,6 +5,8 @@
 import com.ruoyi.sy.service.ArdSyCarRtuService;
 import com.ruoyi.system.service.ISysConfigService;
 import lombok.extern.slf4j.Slf4j;
+import org.eclipse.paho.client.mqttv3.*;
+import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.CommandLineRunner;
 import org.springframework.stereotype.Component;
@@ -31,10 +33,31 @@
     public void init() {
         //鑾峰彇鐢电閿佸湴鍧�
         String mqttUrl = sysConfigService.selectConfigByKey("ElectromagneticLockUrl");
-        List<ArdSyCarRtu> rtus = ardSyCarRtuService.allCarTopic();
+        List<ArdSyCarRtu> rtus = ardSyCarRtuService.allCarTopicList();
         for (int i = 0; i < rtus.size(); i++) {
             ArdSyCarRtu rtu = rtus.get(i);
-            String publish = rtu.getTopicPublish();
+            String carId = rtu.getCarId();
+            String subscribe = rtu.getTopicSubscribe();
+            try {
+                MqttClient client = new MqttClient(mqttUrl,carId);
+//                log.debug("--鍒涘缓"+carId+"鍙疯溅杈嗙數瀛愰攣mqtt瀹㈡埛绔�");
+                MqttConnectOptions options = new MqttConnectOptions();
+                //璁剧疆鐢ㄦ埛鍚嶅瘑鐮�
+                options.setUserName("admin");
+                options.setPassword("xzx12345".toCharArray());
+                // 璁剧疆瓒呮椂鏃堕棿
+                options.setConnectionTimeout(100);
+                // 璁剧疆浼氳瘽蹇冭烦鏃堕棿
+                options.setKeepAliveInterval(60);
+                // 鏄惁娓呴櫎session
+                options.setCleanSession(true);
+//                log.debug("--鐢熸垚"+carId+"鍙疯溅杈嗙數瀛愰攣mqtt閰嶇疆瀵硅薄");
+                client.setCallback(new MqttOnceCallback(client,options,subscribe,2));
+//                log.debug("--娣诲姞杞﹁締鐢电閿佸洖璋冨鐞嗙被");
+                client.connect(options);
+            }catch (Exception e) {
+                e.printStackTrace();
+            }
         }
 //        MqttConsumer mqttConsumer = new MqttConsumer();
 //        for (int i = 0; i < topic.length; i++) {
diff --git a/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnceCallback.java b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnceCallback.java
new file mode 100644
index 0000000..32dc146
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/utils/mqtt/MqttOnceCallback.java
@@ -0,0 +1,98 @@
+package com.ruoyi.utils.mqtt;
+
+import com.ruoyi.alarm.global.service.impl.GlobalAlarmServiceImpl;
+import com.ruoyi.alarm.radar.service.ArdRadarService;
+import com.ruoyi.common.utils.spring.SpringUtils;
+import com.ruoyi.statistical.service.StatisticalService;
+import com.ruoyi.storage.minio.service.IStorageMinioEventService;
+import lombok.extern.slf4j.Slf4j;
+import org.eclipse.paho.client.mqttv3.*;
+
+import java.nio.charset.StandardCharsets;
+import java.util.Arrays;
+
+/**
+ * @Description: mqtt鍥炶皟澶勭悊绫�
+ * @ClassName: MqttConsumerCallback
+ * @Author: 鍒樿嫃涔�
+ * @Date: 2023骞�05鏈�29鏃�9:55
+ * @Version: 1.0
+ **/
+@Slf4j(topic = "mqtt")
+public class MqttOnceCallback implements MqttCallbackExtended {
+
+    private MqttClient client;
+    private MqttConnectOptions options;
+    private String topic;
+    private int qos;
+
+    public MqttOnceCallback(MqttClient client, MqttConnectOptions options, String topic, int qos) {
+        this.client = client;
+        this.options = options;
+        this.topic = topic;
+        this.qos = qos;
+    }
+
+    /**
+     * 鏂紑閲嶈繛
+     */
+    @Override
+    public void connectionLost(Throwable cause) {
+//        log.info("杞﹁締鐢电閿丮QTT杩炴帴鏂紑锛屽彂璧烽噸杩�......");
+        while (!client.isConnected()) {
+            try {
+                Thread.sleep(10000);
+                if (null != client && !client.isConnected()) {
+                    client.reconnect();
+//                    log.error("杞﹁締鐢电閿佸皾璇曢噸鏂拌繛鎺�");
+                } else {
+                    client.connect(options);
+//                    log.error("杞﹁締鐢电閿佸皾璇曞缓绔嬫柊杩炴帴");
+                }
+            } catch (Exception e) {
+//                log.error("杞﹁締鐢电閿佹柇寮�閲嶈繛寮傚父:" + e.getMessage());
+            }
+        }
+    }
+
+    /**
+     * 鎺ユ敹鍒版秷鎭皟鐢ㄤ护鐗屼腑璋冪敤
+     */
+    @Override
+    public void deliveryComplete(IMqttDeliveryToken token) {
+        //log.info("deliveryComplete---------" + Arrays.toString(topic));
+    }
+
+    /**
+     * 娑堟伅澶勭悊
+     */
+    @Override
+    public void messageArrived(String topic, MqttMessage message) {
+        try {
+            System.out.println("銆愯溅杈嗛攣涓婚銆戯細"+topic+"銆愯溅杈嗛攣淇℃伅銆戯細"+new String(message.getPayload(), StandardCharsets.UTF_8));
+        } catch (Exception e) {
+            log.debug("杞﹁締鐢电閿佸鐞唌qtt娑堟伅寮傚父:" + e);
+        }
+    }
+
+    /**
+     * mqtt杩炴帴鍚庤闃呬富棰�
+     */
+    @Override
+    public void connectComplete(boolean b, String s) {
+        try {
+            if (null != topic) {
+                if (client.isConnected()) {
+                    client.subscribe(topic, qos);
+//                    log.info("杞﹁締鐢电閿乵qtt杩炴帴鎴愬姛" );
+//                    log.info("--杞﹁締鐢电閿佽闃呬富棰�:锛�" + topic);
+                } else {
+                    log.info("杞﹁締鐢电閿乵qtt杩炴帴澶辫触");
+                }
+            }
+        } catch (Exception e) {
+            log.info("杞﹁締鐢电閿乵qtt璁㈤槄涓婚寮傚父:" + e);
+        }
+    }
+}
+

--
Gitblit v1.9.3