From 55811ddff81bc142eac3c27e44f30c55e84311f1 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期六, 20 七月 2024 13:25:19 +0800
Subject: [PATCH] 三一车辆遗漏提交

---
 ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java      |  193 +++++++++++++++---------------------------------
 ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java         |    2 
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java |    6 +
 3 files changed, 68 insertions(+), 133 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java
index 4cb0a4d..180acbe 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java
@@ -12,24 +12,27 @@
 import com.gps31.push.netty.PushMsg;
 import com.gps31.push.netty.client.TcpClient;
 import com.gps31.push.util.MapUtil;
+import com.ruoyi.common.core.domain.entity.SysConfig;
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.sy.domain.ArdSyCarLock;
 import com.ruoyi.sy.domain.ArdSyCarRtu;
+import com.ruoyi.sy.domain.ArdTankLock;
 import com.ruoyi.sy.service.ArdSyCarLockService;
 import com.ruoyi.sy.service.ArdSyCarRtuService;
 import com.ruoyi.sy.service.impl.ArdSyCarDayServiceImpl;
 import com.ruoyi.sy.service.impl.ArdSyCarServiceImpl;
 import com.ruoyi.sy.service.impl.ArdTankAbnormalParkAlarmServiceImpl;
+import com.ruoyi.sy.service.impl.ArdTankLockServiceImpl;
+import com.ruoyi.system.service.impl.SysConfigServiceImpl;
+import com.ruoyi.utils.forest.SYClient;
 import com.ruoyi.utils.qymqtt.newM.EmqClient;
 import com.ruoyi.utils.qymqtt.newM.QosEnum;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.codec.digest.DigestUtils;
 import org.eclipse.paho.client.mqttv3.MqttException;
 
 import java.math.BigDecimal;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.UUID;
+import java.util.*;
 
 /**
  * <p>Description: </p>
@@ -49,10 +52,62 @@
 
     private String password;
 
+    private Timer lockStateTimer;
+
     public PushClientImplSerialPort(String ip, String userId, String password) {
         this.ip = ip;
         this.userId = userId;
         this.password = password;
+
+        /*Date date = new Date();
+        this.lockStateTimer = new Timer();//瀹氭椂鑾峰彇鍚勪釜閿佺殑鐘舵��
+        TimerTask lockStateTask =new TimerTask(){
+            @Override
+            public void run(){
+                SysConfig config = new SysConfig();
+                config.setConfigKey("syCarPT");
+                List<SysConfig> sysConfigResult = ((SysConfigServiceImpl)SpringUtils.getBean("sysConfigServiceImpl")).selectConfigList(config);
+                String syURL = "";
+
+                if(sysConfigResult.size() == 0){//涓変竴杞﹁締鍔犲叆寮�鍏�
+                    return;
+                }else{
+                    syURL = sysConfigResult.get(0).getConfigValue();
+                }
+                String passwordMd5 = DigestUtils.md5Hex(password);
+                Map<String, Object> LogInResult = ((SYClient)SpringUtils.getBean("sYClient")).logIn(syURL, passwordMd5, userId);
+                String sessionId = (String) LogInResult.get("sessionId");
+
+                String finalSyURL = syURL;
+                Thread thread = new Thread(finalSyURL){
+                    @Override
+                    public void run() {
+                        List<ArdTankLock> result = ((ArdTankLockServiceImpl)SpringUtils.getBean("ardTankLockServiceImpl")).getArdTankLockAll();//鏌ヨ鍏ㄩ儴鐢电閿�
+                        for(ArdTankLock ardTankLock : result){
+                            //Thread LockThread = new Thread(finalSyURL){
+                                String lockNumHead = ardTankLock.getLockNum().substring(0,2);
+                                String lockNumTail = ardTankLock.getLockNum().substring(2,4);
+                                //璁$畻鏍¢獙
+                                String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16) + Integer.parseInt(lockNumTail, 16) + Integer.parseInt("01", 16));
+
+                                if(checkNum.length() == 1){
+                                    checkNum = "0" + checkNum;
+                                }else if(checkNum.length() > 2){
+                                    checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length());
+                                }
+
+                                String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "01" + checkNum + "%22%7D";
+
+                               //Map<String,Object> result = ((SYClient)SpringUtils.getBean("sYClient")).sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                            //};
+                            //LockThread.start();
+                        }
+                    }
+                };
+                thread.start();
+            }
+        };
+        lockStateTimer.scheduleAtFixedRate(lockStateTask,date,1000);*/
     }
 
     public PushClientImplSerialPort() {
@@ -109,7 +164,7 @@
     public void sendMassage() {
         try {
             PushClientImplSerialPort client = new PushClientImplSerialPort();
-            client.setLog(false);//鏄惁鎵撳嵃鏄庢枃
+            client.setLog(true);//鏄惁鎵撳嵃鏄庢枃
             client.setHost(this.ip);//鏈嶅姟鍣↖P
             client.setPort(10100);//鏈嶅姟鍣ㄧ鍙�
             client.setUserName(this.userId);//绯荤粺鐢ㄦ埛鍚�
@@ -129,133 +184,5 @@
     public void run() {
         sendMassage();
     }
-
-    private void feng(String carId,String type,ArdSyCarRtuService carRtuService,ArdSyCarLockService lockService) throws MqttException {
-        //鏌ヨ瑁呮补鐐规棦瀹歊tu鐘舵��
-        ArdSyCarRtu ardSyCarRtu = carRtuService.one(carId);
-        if(ardSyCarRtu!=null){
-            //鏌ヨ閿佷俊鎭�
-            List<ArdSyCarLock> ardSyCarLocks = lockService.carLock(ardSyCarRtu.getId());
-            if(ardSyCarLocks.size()>0){
-                Integer fengType = null;
-                if("瑁呮补鐐�".equals(type)){
-                    fengType = ardSyCarRtu.getInstallType();
-                }else if("鍗告补鐐�".equals(type)){
-                    fengType = ardSyCarRtu.getUnloadType();
-                }else if("鏂藉皝".equals(type)){
-                    fengType = 0;
-                }
-                //1瑙e皝
-                if(fengType==1){
-                    //濡傛灉涓嶆槸瑙e皝灏佺姸鎬侊紝鍒欏彂閫佹柦灏佸懡浠�
-                    if(ardSyCarLocks.get(0).getRelayInfo()==0 || ardSyCarLocks.get(0).getRelayInfo()==null){
-//                            Map<String,Object> map = new HashMap<>();
-//                            map.put("A01", 110000);//瀵奸�氱涓�璺户鐢靛櫒
-//                            map.put("A02", 110000);//瀵奸�氱浜岃矾缁х數鍣�
-//                            map.put("res", String.valueOf(System.currentTimeMillis()));
-//                            String mapString = com.alibaba.fastjson.JSON.toJSONString(map);
-                        String mapString = "{\"A01\":110000,\"A02\":110000,\"res\":\""+String.valueOf(System.currentTimeMillis())+"\"}";
-                        log.debug("鑷姩瑙e皝锛�"+mapString);
-                        EmqClient emqClient = new EmqClient(carId+"mqttPublish"+UUID.randomUUID());
-                        emqClient.connect();
-                        emqClient.publish(ardSyCarRtu.getTopicPublish(),mapString, QosEnum.QoS2,false);
-                        log.debug("杞﹁締"+carId+"瑙e皝鍛戒护鍙戦�佹垚鍔燂紒");
-                        //                mqttOnce.publishCar(carId,ardSyCarRtu.getTopicPublish(),String.valueOf(new JSONObject(map)),"瑙e皝");
-                    }
-                }
-
-                //0鏂藉皝
-                if(fengType==0){
-                    if(ardSyCarLocks.get(0).getRelayInfo()==1 || ardSyCarLocks.get(0).getRelayInfo()==null){
-                        //閿佸紑鍏崇姸鎬�
-                        int lockCloseNum = 0;
-                        String mapString1 = "{\"A01\":100000,\"A02\":100000,\"res\":\""+String.valueOf(System.currentTimeMillis())+"\"}";
-                        System.out.println("鑷姩鏂藉皝锛�"+mapString1);
-                        EmqClient emqClient1 = new EmqClient(carId+"mqttPublish"+UUID.randomUUID());
-                        emqClient1.connect();
-                        emqClient1.publish(ardSyCarRtu.getTopicPublish(),mapString1, QosEnum.QoS2,false);
-                        //濡傛灉涓嶆槸鏂藉皝鐘舵�侊紝鍒欏彂閫佹柦灏佸懡浠�
-                        if(ardSyCarLocks.get(0).getRelayInfo()!=null){
-                            if(ardSyCarLocks.get(0).getRelayInfo()==1){
-                                for (int j = 0; j < ardSyCarLocks.size(); j++) {
-                                    ArdSyCarLock ardSyCarLock = ardSyCarLocks.get(j);
-                                    String currents = ardSyCarLock.getCurrents();
-                                    Double currentInfo = ardSyCarLock.getCurrentInfo();
-                                    //鐢垫祦鍊间负4.0鏄叧閿佺姸鎬�
-                                    if(currentInfo.equals(4.00) || currentInfo.equals(4)){
-                                        lockCloseNum += 1;
-                                    }else {
-                                        String key = "";
-                                        if(currents.equals("C01")){
-                                            key = "D03";
-                                        }else if(currents.equals("C02")){
-                                            key = "D04";
-                                        }
-//                                    Map<String,Object> map = new HashMap();
-//                                    map.put(key, 0.01);
-//                                    map.put("res", String.valueOf(System.currentTimeMillis()));
-//                                    String mapString = com.alibaba.fastjson.JSON.toJSONString(map);
-                                        String mapString = "{\""+key+"\":0.01,\"res\":\""+String.valueOf(System.currentTimeMillis())+"\"}";
-                                        log.debug("鑷姩鍏抽攣锛�"+mapString);
-                                        EmqClient emqClient = new EmqClient(carId+"mqttPublish"+UUID.randomUUID());
-                                        emqClient.connect();
-                                        emqClient.publish(ardSyCarRtu.getTopicPublish(),mapString, QosEnum.QoS2,false);
-                                        //                        mqttOnce.publishCar("carId",ardSyCarRtu.getTopicPublish(),String.valueOf(new JSONObject(map)),"寮�閿侊細"+currents);
-                                        while(true){
-                                            ArdSyCarLock ardSyCarLock1 = lockService.getCurrentInfo(ardSyCarRtu.getId(),currents);
-                                            Double currentInfo1 = ardSyCarLock1.getCurrentInfo();
-                                            if(currentInfo1.equals(4.00) || currentInfo1.equals(4)){
-                                                lockCloseNum +=1;
-                                                break;
-                                            }
-                                        }
-                                    }
-                                }
-                                if(lockCloseNum == 2){
-//                                Map<String,Object> map = new HashMap<>();
-//                                map.put("A01", 100000);//鏂紑绗竴璺户鐢靛櫒
-//                                map.put("A02", 100000);//鏂紑绗簩璺户鐢靛櫒
-//                                map.put("res", String.valueOf(System.currentTimeMillis()));
-//                                String mapString = com.alibaba.fastjson.JSON.toJSONString(map);
-                                    log.debug("杞﹁締"+carId+"鏂藉皝鍛戒护鍙戦�佹垚鍔燂紒");
-                                    //                    mqttOnce.publishCar(carId,ardSyCarRtu.getTopicPublish(),String.valueOf(new JSONObject(map)),"鏂藉皝");
-                                }
-                            }
-                        }
-                    }
-                }
-            }
-        }
-    }
-
-    public Double[] azimuth_offset(double origin_lon, double origin_lat, Integer direction,double distance){
-        Double[] lonlat = new Double[2];
-        if(direction != null && distance > 0){
-            lonlat[0] = origin_lon + distance * Math.sin(direction* Math.PI / 180) * 180 / ( Math.PI * 6371229 * Math.cos(origin_lat * Math.PI / 180));
-            lonlat[1] = origin_lat + distance * Math.cos(direction* Math.PI / 180) / ( Math.PI * 6371229 / 180);
-        }else{
-            lonlat[0] = origin_lon;
-            lonlat[1] = origin_lat;
-        }
-        return lonlat;
-    }
-
-    public Double getDistance(Double velocity ,Double acceleration ,String time){
-        Double distance = velocity*Double.parseDouble(time) + 0.5*acceleration*Double.parseDouble(time)*Double.parseDouble(time);
-        return distance;
-    }
-
-    /*public Double getVelocity(Double velocity ,Double acceleration ,String time){
-        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-        Long t = (long) 0;
-        try {
-            t = (new Date().getTime() - simpleDateFormat.parse(time).getTime())/1000;
-        } catch (Exception e) {
-            // TODO Auto-generated catch block
-            e.printStackTrace();
-        }
-        Double velocityt = velocity + acceleration*t;
-        return velocityt;
-    }*/
 
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java
index bebf257..c656a1d 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java
@@ -72,4 +72,6 @@
     public int updateLockByCarId(Map<String,Object> para);
 
     public Map<String,Object> getLockByCarPlate(String usersId, String carPlate, Integer pageNum, Integer pageSize);
+
+    public List<ArdTankLock> getArdTankLockAll();
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java
index d69b288..b84a53c 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java
@@ -433,4 +433,10 @@
         mapResult.put("total",total);
         return mapResult;
     }
+
+    @Override
+    public List<ArdTankLock> getArdTankLockAll() {
+        List<ArdTankLock> result = ardTankLockMapper.getAll();
+        return result;
+    }
 }

--
Gitblit v1.9.3