From 93cecfaf0fae080ebd0212adea714726290d0d4a Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期四, 01 八月 2024 20:36:54 +0800
Subject: [PATCH] 电磁锁串口协议发送加入线程排队提交

---
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockStateServiceImpl.java      |    6 
 ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml                               |   10 +
 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java                         |    2 
 ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java                       |    9 +
 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java                      |    2 
 ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java                   |    2 
 ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml                            |   10 +
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java                 |  264 +++++++++++++++++++++++----------
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java |    4 
 ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java                      |    2 
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java           |  144 ++++++++++++------
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java              |    6 
 12 files changed, 324 insertions(+), 137 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
index 3ed0961..b8f26ca 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
@@ -153,6 +153,17 @@
         //鍒犻櫎缁撴潫鏃堕棿涓簄ull鐨勮褰�
         int result = ardTankAbnormalParkAlarmService.deleteArdTankAbnormalParkAlarmByEndTime();
 
+        List<ArdSyCar> ardSyCarAndLockList = ardSyCarService.selectArdSyCarAndTankLock();//鏌ヨ鍏ㄩ儴缃愯溅鍙婁笅鎸傜數纾侀攣
+
+        for(ArdSyCar ardSyCar : ardSyCarAndLockList){//鏋勯�犲鍣�
+            Map<String,Map<String,Thread>> carMap = new HashMap();//杞﹁締瀹瑰櫒
+            for(ArdTankLock ardTankLock : ardSyCar.getArdTankLockList()){
+                Map<String,Thread> lockMap = new HashMap();//閿佸鍣�
+                carMap.put(ardTankLock.getLockNum(),lockMap);
+            }
+            PositionContainer.getCarLockProcessThreadMap().put(ardSyCar.getCarId(),carMap);
+        }
+
         Timer lockStateTimer = new Timer();//瀹氭椂鑾峰彇鍚勪釜閿佺殑鐘舵��
         TimerTask lockStateTask =new TimerTask(){
             @Override
@@ -193,11 +204,17 @@
                                     }
 
                                     String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "01" + checkNum + "%22%7D";
-
-                                    sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                    try{
+                                        sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockState");
+                                    }catch(Exception e){
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockState");
+                                    }
                                 }
                             };
-                            lockThread.start();
+                            //lockThread.start();
+                            //灏嗙姸鎬佺嚎绋嬫斁鍏ュ鍣�
+                            PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).put("lockState",lockThread);
                         }
                     }
                 };
@@ -209,86 +226,92 @@
 
         SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         Timer lockCheckTimeTimer = new Timer();//瀹氭椂鏍″噯鏃堕棿
-        TimerTask lockCheckTimeTask =new TimerTask(){
+        TimerTask lockCheckTimeTask = new TimerTask(){
             @Override
             public void run() {
-            SysConfig config = new SysConfig();
-            config.setConfigKey("syCarPT");
-            List<SysConfig> sysConfigResult = sysConfigService.selectConfigList(config);
-            String syURL = "";
+                SysConfig config = new SysConfig();
+                config.setConfigKey("syCarPT");
+                List<SysConfig> sysConfigResult = sysConfigService.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.logIn(syURL, passwordMd5, userId);
-            String sessionId = (String) LogInResult.get("sessionId");
+                if(sysConfigResult.size() == 0){
+                    return;
+                }else{
+                    syURL = sysConfigResult.get(0).getConfigValue();
+                }
+                String passwordMd5 = DigestUtils.md5Hex(password);
+                Map<String, Object> LogInResult = sYClient.logIn(syURL, passwordMd5, userId);
+                String sessionId = (String) LogInResult.get("sessionId");
 
-            String finalSyURL = syURL;
+                String finalSyURL = syURL;
 
-            List<ArdTankLock> result = ardTankLockService.getArdTankLockAll();//鏌ヨ鍏ㄩ儴鐢电閿�
-            for(ArdTankLock ardTankLock : result){
-                Thread lockThread = new Thread(finalSyURL){
-                    @Override
-                    public void run() {
-                        //鑾峰彇鏃堕棿骞舵媶鍒嗗勾鏈堟棩鏃跺垎绉�
-                        String nowTime = sdf.format(new Date());
-                        String nowYear = nowTime.substring(2,4);
-                        String nowMonth = nowTime.substring(5,7);
-                        String nowDay = nowTime.substring(8,10);
-                        String nowHour = nowTime.substring(11,13);
-                        String nowMinute = nowTime.substring(14,16);
-                        String nowSecond = nowTime.substring(17,19);
+                List<ArdTankLock> result = ardTankLockService.getArdTankLockAll();//鏌ヨ鍏ㄩ儴鐢电閿�
+                for(ArdTankLock ardTankLock : result){
+                    Thread lockThread = new Thread(finalSyURL){
+                        @Override
+                        public void run() {
+                            //鑾峰彇鏃堕棿骞舵媶鍒嗗勾鏈堟棩鏃跺垎绉�
+                            String nowTime = sdf.format(new Date());
+                            String nowYear = nowTime.substring(2,4);
+                            String nowMonth = nowTime.substring(5,7);
+                            String nowDay = nowTime.substring(8,10);
+                            String nowHour = nowTime.substring(11,13);
+                            String nowMinute = nowTime.substring(14,16);
+                            String nowSecond = nowTime.substring(17,19);
 
-                        String nowYearHex = Integer.toHexString(Integer.parseInt(nowYear));
-                        if(nowYearHex.length() == 1){
-                            nowYearHex = "0" + nowYearHex;
+                            String nowYearHex = Integer.toHexString(Integer.parseInt(nowYear));
+                            if(nowYearHex.length() == 1){
+                                nowYearHex = "0" + nowYearHex;
+                            }
+                            String nowMonthHex = Integer.toHexString(Integer.parseInt(nowMonth));
+                            if(nowMonthHex.length() == 1){
+                                nowMonthHex = "0" + nowMonthHex;
+                            }
+                            String nowDayHex = Integer.toHexString(Integer.parseInt(nowDay));
+                            if(nowDayHex.length() == 1){
+                                nowDayHex = "0" + nowDayHex;
+                            }
+                            String nowHourHex = Integer.toHexString(Integer.parseInt(nowHour));
+                            if(nowHourHex.length() == 1){
+                                nowHourHex = "0" + nowHourHex;
+                            }
+                            String nowMinuteHex = Integer.toHexString(Integer.parseInt(nowMinute));
+                            if(nowMinuteHex.length() == 1){
+                                nowMinuteHex = "0" + nowMinuteHex;
+                            }
+                            String nowSecondHex = Integer.toHexString(Integer.parseInt(nowSecond));
+                            if(nowSecondHex.length() == 1){
+                                nowSecondHex = "0" + nowSecondHex;
+                            }
+                            //16杩涘埗鏃堕棿
+                            String timeHex = nowYearHex + nowMonthHex + nowDayHex + nowHourHex + nowMinuteHex + nowSecondHex;
+                            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("08", 16) +
+                                    Integer.parseInt(nowYearHex, 16) + Integer.parseInt(nowMonthHex, 16) + Integer.parseInt(nowDayHex, 16) +
+                                    Integer.parseInt(nowHourHex, 16) + Integer.parseInt(nowMinuteHex, 16) + Integer.parseInt(nowSecondHex, 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() + "08" + timeHex + checkNum + "%22%7D";
+                            try{
+                                sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockTime");
+                            }catch(Exception e){
+                                PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockTime");
+                            }
                         }
-                        String nowMonthHex = Integer.toHexString(Integer.parseInt(nowMonth));
-                        if(nowMonthHex.length() == 1){
-                            nowMonthHex = "0" + nowMonthHex;
-                        }
-                        String nowDayHex = Integer.toHexString(Integer.parseInt(nowDay));
-                        if(nowDayHex.length() == 1){
-                            nowDayHex = "0" + nowDayHex;
-                        }
-                        String nowHourHex = Integer.toHexString(Integer.parseInt(nowHour));
-                        if(nowHourHex.length() == 1){
-                            nowHourHex = "0" + nowHourHex;
-                        }
-                        String nowMinuteHex = Integer.toHexString(Integer.parseInt(nowMinute));
-                        if(nowMinuteHex.length() == 1){
-                            nowMinuteHex = "0" + nowMinuteHex;
-                        }
-                        String nowSecondHex = Integer.toHexString(Integer.parseInt(nowSecond));
-                        if(nowSecondHex.length() == 1){
-                            nowSecondHex = "0" + nowSecondHex;
-                        }
-                        //16杩涘埗鏃堕棿
-                        String timeHex = nowYearHex + nowMonthHex + nowDayHex + nowHourHex + nowMinuteHex + nowSecondHex;
-                        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("08", 16) +
-                                Integer.parseInt(nowYearHex, 16) + Integer.parseInt(nowMonthHex, 16) + Integer.parseInt(nowDayHex, 16) +
-                                Integer.parseInt(nowHourHex, 16) + Integer.parseInt(nowMinuteHex, 16) + Integer.parseInt(nowSecondHex, 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() + "08" + timeHex + checkNum + "%22%7D";
-
-                        sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
-                    }
-                };
-                lockThread.start();
-            }
+                    };
+                    //lockThread.start();
+                    PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).put("lockTime",lockThread);
+                }
             }
         };
-        lockCheckTimeTimer.scheduleAtFixedRate(lockCheckTimeTask,date,7000);
+        //lockCheckTimeTimer.scheduleAtFixedRate(lockCheckTimeTask,date,7000);
+        lockCheckTimeTimer.scheduleAtFixedRate(lockCheckTimeTask,date,67000);
 
         Timer sendTimer = new Timer();//瀹氭椂鍙戦�侀攣鐘舵��
         TimerTask sendLockStateTask = new TimerTask(){
@@ -314,10 +337,11 @@
                 ardTankLockService.readPassword(userId,password);
             }
         };
-        passwordTimer.scheduleAtFixedRate(passwordTask,date,11000);
+        //passwordTimer.scheduleAtFixedRate(passwordTask,date,11000);
+        passwordTimer.scheduleAtFixedRate(passwordTask,date,13000);
 
         Timer lockRestartStateTimer = new Timer();//瀹氭椂鍚勪釜閿佺殑澶嶄綅鐘舵��
-        TimerTask lockRestartStateTask =new TimerTask(){
+        TimerTask lockRestartStateTask = new TimerTask(){
             @Override
             public void run(){
                 Thread thread = new Thread(){
@@ -376,11 +400,16 @@
                                             }
 
                                             String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "03" + process + checkNum + "%22%7D";
-
-                                            sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                            try{
+                                                sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                                PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockRestart");
+                                            }catch (Exception e){
+                                                PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockRestart");
+                                            }
                                         }
                                     };
-                                    lockThread.start();
+                                    //lockThread.start();
+                                    PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).put("lockRestart",lockThread);
                                 }
                             }
                         }
@@ -389,7 +418,82 @@
                 thread.start();
             }
         };
-        lockRestartStateTimer.scheduleAtFixedRate(lockRestartStateTask,date,9000);
+        lockRestartStateTimer.scheduleAtFixedRate(lockRestartStateTask,date,17000);
+
+        Set<String> lockNumSet = new HashSet();//瀛樻斁鍙戦�佽繃鐨勯攣缂栧彿
+
+        Timer mainLockTimer = new Timer();//涓诲畾鏃跺櫒
+        TimerTask mainLockTask = new TimerTask(){
+            @Override
+            public void run() {
+                Long count = ardTankLockService.getArdTankLockCount();
+                if(lockNumSet.size() >= count){//闃叉閿佽鍒犻櫎锛岄噰鐢ㄥぇ浜庣瓑浜�
+                    lockNumSet.clear();//鍏ㄩ儴鎵ц杩囷紝娓呯┖瀹瑰櫒
+                }
+                for(String carId : PositionContainer.getCarLockProcessThreadMap().keySet()){
+                    Thread thread = new Thread(){
+                        @Override
+                        public void run() {
+                            Map<String, Map<String,Thread>> lockMap = PositionContainer.getCarLockProcessThreadMap().get(carId);
+                            for(String lockNum : lockMap.keySet()){
+                                if(lockNumSet.contains(lockNum)){//鑻ユ墽琛岃繃锛屾湰娆″拷鐣�
+                                    continue;
+                                }
+                                if(lockMap.get(lockNum).get("lockProcess") != null){
+                                    break;//閿佹搷浣滅骇鍒渶楂�
+                                }else{
+                                    if(lockMap.get(lockNum).get("lockTime") != null){
+                                        if(lockMap.get(lockNum).get("lockTime").isAlive()){
+                                            lockNumSet.add(lockNum);
+                                            break;//閿佹牎鏃舵涔�
+                                        }else{
+                                            lockMap.get(lockNum).get("lockTime").start();
+                                            lockNumSet.add(lockNum);
+                                            break;//閿佹牎鏃舵涔�
+                                        }
+                                    }else{
+                                        if(lockMap.get(lockNum).get("lockPassword") != null){
+                                            if(lockMap.get(lockNum).get("lockPassword").isAlive()){
+                                                lockNumSet.add(lockNum);
+                                                break;//閿佸瘑鐮佹涔�
+                                            }else{
+                                                lockMap.get(lockNum).get("lockPassword").start();
+                                                lockNumSet.add(lockNum);
+                                                break;//閿佸瘑鐮佹涔�
+                                            }
+                                        }else{
+                                            if(lockMap.get(lockNum).get("lockRestart") != null) {
+                                                if(lockMap.get(lockNum).get("lockRestart").isAlive()){
+                                                    lockNumSet.add(lockNum);
+                                                }else{
+                                                    lockMap.get(lockNum).get("lockRestart").start();
+                                                    lockNumSet.add(lockNum);
+                                                    break;//閿佸浣嶆涔�
+                                                }
+                                            }else{
+                                                if(lockMap.get(lockNum).get("lockState") != null) {
+                                                    if(lockMap.get(lockNum).get("lockState").isAlive()){
+                                                        lockNumSet.add(lockNum);
+                                                    }else{
+                                                        lockMap.get(lockNum).get("lockState").start();
+                                                        lockNumSet.add(lockNum);
+                                                        break;//閿佺姸鎬佹涔�
+                                                    }
+                                                }else{
+                                                    break;
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    };
+                    thread.start();
+                }
+            }
+        };
+        mainLockTimer.scheduleAtFixedRate(mainLockTask,date,2000);
 
     }
 
diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java
index 45ea361..6d39843 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java
@@ -19,7 +19,7 @@
 
     private static Map<String, Set<String>> carLockPasswordMap = new HashMap();//渚濈數纾侀攣缂栧彿瀛樻斁鐢熸垚鐨勫瘑鐮�
 
-
+    private static Map<String, Map<String, Map<String,Thread>>> carLockProcessThreadMap = new HashMap();//渚濊溅杈嗭紝鐢电閿侊紝鎿嶄綔绫诲瀷瀛樻斁绾跨▼;lockState:閿佺姸鎬�,lockTime:閿佹牎鏃�,lockPassword:閿佸瘑鐮�(鍖呮嫭璇诲啓),lockRestart:閿佸浣�,lockProcess:閿佹搷浣�
 
     public static Map<String, List<ArdSyCarLock>> getTopicSubscribe() {
         return topicSubscribe;
@@ -72,4 +72,11 @@
         PositionContainer.carLockPasswordMap = carLockPasswordMap;
     }
 
+    public static synchronized Map<String, Map<String, Map<String, Thread>>> getCarLockProcessThreadMap() {
+        return carLockProcessThreadMap;
+    }
+
+    public static synchronized void setCarLockProcessThreadMap(Map<String, Map<String, Map<String, Thread>>> carLockProcessThreadMap) {
+        PositionContainer.carLockProcessThreadMap = carLockProcessThreadMap;
+    }
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
index f7f3dfb..bb7dbe8 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
@@ -96,4 +96,6 @@
     public List<ArdSyCar> selectArdSyCarAndTankLockByUserId(String userId);
 
     public List<ArdSyCar> selectByBrandAndType(@Param("carBrand")String carBrand,@Param("carType")String carType);
+
+    public List<ArdSyCar> selectArdSyCarAndTankLock();
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java
index 8a9fa90..37c074f 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java
@@ -87,4 +87,6 @@
     public List<ArdTankLock> selectArdTankLockWithPassword();
 
     public List<ArdTankLock> getArdTankLockAllWithState();
+
+    public Long getArdTankLockCount();
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
index 557ae98..8e1beda 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
@@ -165,4 +165,6 @@
     Map<String, Object> getAlarmHPfmCountDetail(String sessionId,String usersId,String carId,String startTime,String endTime,String syURL);
 
     public Map<String,Object> getOnlineSYCarPosition(String soilderId);
+
+    public List<ArdSyCar> selectArdSyCarAndTankLock();
 }
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 0d1d224..2803f8f 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
@@ -81,5 +81,7 @@
 
     public List<ArdTankLock> getArdTankLockAllWithState();
 
+    public Long getArdTankLockCount();
+
     //public void getAlarm(String syUserId,String syPassword);
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
index 1aa0bbf..7a32f66 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
@@ -1553,6 +1553,12 @@
         }
     }
 
+    @Override
+    public List<ArdSyCar> selectArdSyCarAndTankLock() {
+        List<ArdSyCar> result = ardSyCarMapper.selectArdSyCarAndTankLock();
+        return result;
+    }
+
     public List<Long> getOwnAndChildrenDeptIdList(List<Long> deptIdList,List<Long> deptIdListr){
         deptIdListr.addAll(deptIdList);
         List<Long> result = sysDeptMapper.getChildrenDeptIdList(deptIdList);
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java
index 0038f30..e39bf04 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java
@@ -12,6 +12,7 @@
 import com.ruoyi.sy.domain.ArdSyUser;
 import com.ruoyi.sy.domain.ArdTankLock;
 import com.ruoyi.sy.domain.ArdTankWall;
+import com.ruoyi.sy.gps31.PositionContainer;
 import com.ruoyi.sy.mapper.ArdSyUserMapper;
 import com.ruoyi.sy.mapper.ArdTankLockMapper;
 import com.ruoyi.sy.mapper.ArdTankWallMapper;
@@ -208,7 +209,9 @@
 
                 String paramsStr = lockNum + "02" + process + checkNum;
                 paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + paramsStr + "%22%7D";
+                PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
                 Map<String,Object> result = sendCmd(syURL, ardSyUser.getUserId(), carId, 199, "DataDownTransfer", paramsStr, sessionId);
+                PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒
                 if(((String)result.get("rspCode")).equals("0")){
                     ArdTankLockProcessLog ardTankLockProcessLog = new ArdTankLockProcessLog();
                     ardTankLockProcessLog.setId(IdUtils.simpleUUID());
@@ -252,6 +255,7 @@
                 }
             }catch(Exception e){
                 e.printStackTrace();
+                PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒
                 return AjaxResult.error("鍙戦�佸け璐�" + e.toString());
             }
         }
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 b7a27df..7e3fc5c 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
@@ -110,7 +110,24 @@
             ardTankLock.setRestartState(map.get("restartState"));
             ardTankLocks.add(ardTankLock);
         }
-        return ardTankLockMapper.insertArdTankLocks(ardTankLocks);
+        try{
+            return ardTankLockMapper.insertArdTankLocks(ardTankLocks);
+        }finally {
+            if(PositionContainer.getCarLockProcessThreadMap().keySet().contains(carId)){
+                Map<String, Map<String,Thread>> lockMap = PositionContainer.getCarLockProcessThreadMap().get(carId);
+                for(Map<String,String> map : lockList){
+                    Map<String,Thread> lockThreadMap = new HashMap();
+                    lockMap.put(map.get("lockNum"),lockThreadMap);
+                }
+            }else{
+                Map<String,Map<String,Thread>> carMap = new HashMap();//杞﹁締瀹瑰櫒
+                for(Map<String,String> map : lockList){
+                    Map<String,Thread> lockMap = new HashMap();//閿佸鍣�
+                    carMap.put(map.get("lockNum"),lockMap);
+                }
+                PositionContainer.getCarLockProcessThreadMap().put(carId,carMap);
+            }
+        }
     }
     /*@Override
     public int insertArdTankLock(ArdTankLock ardTankLock) {
@@ -312,7 +329,11 @@
     @Override
     public int deleteLockByCarId(String carId) {
         int result = ardTankLockMapper.deleteLockByCarId(carId);
-        return result;
+        try{
+            return result;
+        }finally {
+            PositionContainer.getCarLockProcessThreadMap().remove(carId);//绉婚櫎瀹瑰櫒
+        }
     }
 
     @Override
@@ -331,7 +352,11 @@
                 return 1;
             }
             result = ardTankLockMapper.deleteLockByCarId(carId);
-            return result;
+            try{
+                return result;
+            }finally {
+                PositionContainer.getCarLockProcessThreadMap().get(carId).clear();
+            }
         }
 
         List<ArdTankLock> ardTankLocks = new ArrayList();
@@ -362,6 +387,22 @@
                 ardTankLocks.add(ardTankLock);
             }
         }
+        //鏇存柊瀹瑰櫒
+        if(PositionContainer.getCarLockProcessThreadMap().keySet().contains(carId)){
+            Map<String, Map<String,Thread>> lockMap = PositionContainer.getCarLockProcessThreadMap().get(carId);
+            for(Map<String,Object> map : lockList){
+                Map<String,Thread> lockThreadMap = new HashMap();
+                lockMap.put((String) map.get("lockNum"),lockThreadMap);
+            }
+        }else{
+            Map<String,Map<String,Thread>> carMap = new HashMap();//杞﹁締瀹瑰櫒
+            for(Map<String,Object> map : lockList){
+                Map<String,Thread> lockMap = new HashMap();//閿佸鍣�
+                carMap.put((String) map.get("lockNum"),lockMap);
+            }
+            PositionContainer.getCarLockProcessThreadMap().put(carId,carMap);
+        }
+
         if(ardTankLocks.size() != 0){
             result = result + ardTankLockMapper.insertArdTankLocks(ardTankLocks);
         }
@@ -696,36 +737,29 @@
                                     }
                                     data = data + checkNum;
                                     String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + data + "%22%7D";
-                                    Map<String,Object> syResult = sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
-                                    if(((String)syResult.get("rspCode")).equals("0")){
-                                        List<ArdTankLockPassword> ardTankLockPasswordList = new ArrayList();
-                                        int i = 0;
-                                        for(String password : passwordSet){
-                                            ArdTankLockPassword ardTankLockPassword = new ArdTankLockPassword();
-                                            ardTankLockPassword.setId(IdUtils.simpleUUID());
-                                            ardTankLockPassword.setLockId(ardTankLock.getLockNum());//鏆傚瓨閿佺紪鍙�
-                                            ardTankLockPassword.setPassword(password);
-                                            ardTankLockPassword.setNo(String.valueOf(i));
-                                            ardTankLockPasswordList.add(ardTankLockPassword);
-                                            i = i + 1;
+
+                                    try{
+                                        Map<String,Object> syResult = sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                        if(((String)syResult.get("rspCode")).equals("0")){
+                                            List<ArdTankLockPassword> ardTankLockPasswordList = new ArrayList();
+                                            int i = 0;
+                                            for(String password : passwordSet){
+                                                ArdTankLockPassword ardTankLockPassword = new ArdTankLockPassword();
+                                                ardTankLockPassword.setId(IdUtils.simpleUUID());
+                                                ardTankLockPassword.setLockId(ardTankLock.getLockNum());//鏆傚瓨閿佺紪鍙�
+                                                ardTankLockPassword.setPassword(password);
+                                                ardTankLockPassword.setNo(String.valueOf(i));
+                                                ardTankLockPasswordList.add(ardTankLockPassword);
+                                                i = i + 1;
+                                            }
+                                            int result = ardTankLockPasswordMapper.insertArdTankLockPasswordList(ardTankLockPasswordList);
+                                            PositionContainer.getCarLockPasswordMap().remove(ardTankLock.getLockNum());
                                         }
-                                        int result = ardTankLockPasswordMapper.insertArdTankLockPasswordList(ardTankLockPasswordList);
-                                        PositionContainer.getCarLockPasswordMap().remove(ardTankLock.getLockNum());
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
+                                    }catch (Exception e){
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
                                     }
                                 }else{//璇诲彇瀵嗙爜
-                                    /*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("05", 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() + "05" + checkNum + "%22%7D";
-
-                                    sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);*/
                                     Set<String> passwordSet = new HashSet();
                                     while(passwordSet.size() != 10){
                                         String password = "";
@@ -734,8 +768,6 @@
                                         }
                                         passwordSet.add(password);
                                     }
-                                    System.out.println("1111111111111111");
-                                    System.out.println(passwordSet);
                                     //璁剧疆鏂板瘑鐮�
                                     String lockNumHead = ardTankLock.getLockNum().substring(0,2);
                                     String lockNumTail = ardTankLock.getLockNum().substring(2,4);
@@ -762,20 +794,25 @@
                                     }
                                     data = data + checkNum;
                                     String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + data + "%22%7D";
-                                    Map<String,Object> syResult = sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
-                                    if(((String)syResult.get("rspCode")).equals("0")){
-                                        List<ArdTankLockPassword> ardTankLockPasswordList = new ArrayList();
-                                        int i = 0;
-                                        for(String password : passwordSet){
-                                            ArdTankLockPassword ardTankLockPassword = new ArdTankLockPassword();
-                                            ardTankLockPassword.setId(IdUtils.simpleUUID());
-                                            ardTankLockPassword.setLockId(ardTankLock.getLockNum());//鏆傚瓨閿佺紪鍙�
-                                            ardTankLockPassword.setPassword(password);
-                                            ardTankLockPassword.setNo(String.valueOf(i));
-                                            ardTankLockPasswordList.add(ardTankLockPassword);
-                                            i = i + 1;
+                                    try{
+                                        Map<String,Object> syResult = sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                        if(((String)syResult.get("rspCode")).equals("0")){
+                                            List<ArdTankLockPassword> ardTankLockPasswordList = new ArrayList();
+                                            int i = 0;
+                                            for(String password : passwordSet){
+                                                ArdTankLockPassword ardTankLockPassword = new ArdTankLockPassword();
+                                                ardTankLockPassword.setId(IdUtils.simpleUUID());
+                                                ardTankLockPassword.setLockId(ardTankLock.getLockNum());//鏆傚瓨閿佺紪鍙�
+                                                ardTankLockPassword.setPassword(password);
+                                                ardTankLockPassword.setNo(String.valueOf(i));
+                                                ardTankLockPasswordList.add(ardTankLockPassword);
+                                                i = i + 1;
+                                            }
+                                            int result = ardTankLockPasswordMapper.insertArdTankLockPasswordList(ardTankLockPasswordList);
                                         }
-                                        int result = ardTankLockPasswordMapper.insertArdTankLockPasswordList(ardTankLockPasswordList);
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
+                                    }catch(Exception e){
+                                        PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
                                     }
                                 }
                             }else{
@@ -790,12 +827,17 @@
                                     checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length());
                                 }
                                 String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "05" + checkNum + "%22%7D";
-
-                                sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                try{
+                                    sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                    PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
+                                }catch (Exception e){
+                                    PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).remove("lockPassword");
+                                }
                             }
                         }
                     };
-                    lockThread.start();
+                    //lockThread.start();
+                    PositionContainer.getCarLockProcessThreadMap().get(ardTankLock.getCarId()).get(ardTankLock.getLockNum()).put("lockPassword",lockThread);
                 }
 
             }
@@ -809,6 +851,12 @@
         return result;
     }
 
+    @Override
+    public Long getArdTankLockCount() {
+        Long result = ardTankLockMapper.getArdTankLockCount();
+        return result;
+    }
+
     /*@Override
     public void getAlarm(String syUserId,String syPassword) {
         List<SysConfig> syURLResult = sysConfigMapper.selectByType("syCarPT");
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockStateServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockStateServiceImpl.java
index 7a0c357..704a386 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockStateServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockStateServiceImpl.java
@@ -109,15 +109,9 @@
             ardTankLockMapper.updateArdTankLock(ardTankLock);//鏇存敼鐘舵��
         }*/
         try{
-            System.out.println("////////////");
-            System.out.println(ardTankLockState.getLockState());
-            System.out.println(ardTankLockState.getUniqueMark());
             int result = ardTankLockStateMapper.insertArdTankLockState(ardTankLockState);
             return result;
         }catch(Exception e){
-            System.out.println("111111111111");
-            System.out.println(ardTankLockState.getLockState());
-            System.out.println(ardTankLockState.getUniqueMark());
             int result = ardTankLockStateMapper.updateArdTankLockStateByUniqueMark(ardTankLockState.getUniqueMark(),ardTankLockState.getUploadTime());
             return result;
         }finally {
diff --git a/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml b/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
index 23e4643..52db00a 100644
--- a/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
+++ b/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
@@ -187,4 +187,14 @@
             <if test="carBrand != null  and carBrand != ''"> and car_brand = #{carBrand}</if>
         </where>
     </select>
+    <select id="selectArdSyCarAndTankLock" resultMap="ArdSyCarLockResult" >
+       select "asc".id,"asc".car_id,"asc".car_model,"asc".car_type,
+       "asc".car_brand,"asc".dept_id,"asc".car_picture,atl.id as lid,
+       atl.lock_num,atl.lock_name,atl.img_position_top,atl.img_position_left,
+       atl.car_id as lcar_id,atl.enable,coalesce(atl.restart_state,'') as restart_state,
+       coalesce(atl.online_time,'') as online_time
+       from ard_sy_car "asc"
+       inner join ard_tank_lock atl on "asc".car_id = atl.car_id
+       order by "asc".car_id desc,atl.lock_num
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
index 5dd0480..ef81f55 100644
--- a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
+++ b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
@@ -170,7 +170,8 @@
         case atls.lock_state
           when '鍏抽攣鐘舵��' then false
           when '寮傚父鐘舵��' then false
-          when '鍔ㄤ綔鐘舵��' then false
+          /*when '鍔ㄤ綔鐘舵��' then false*/
+          when '鎿嶆帶涓�...' then false
           when '寮�閿佺姸鎬�' then true
           else false
           end as lock_state_mark,
@@ -257,7 +258,8 @@
         case atls.lock_state
             when '鍏抽攣鐘舵��' then false
             when '寮傚父鐘舵��' then false
-            when '鍔ㄤ綔鐘舵��' then false
+            /*when '鍔ㄤ綔鐘舵��' then false*/
+            when '鎿嶆帶涓�...' then false
             when '寮�閿佺姸鎬�' then true
             else false
             end as lock_state_mark,
@@ -265,4 +267,8 @@
         from ard_tank_lock atl
         left join ard_tank_lock_state atls on atl."id" = atls.lock_id)t where t.rn = 1
     </select>
+
+    <select id="getArdTankLockCount" resultType="java.lang.Long" >
+        select count(*) from ard_tank_lock
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.3