From b468cde8bfd9d6e1d7ae7ccc535fc7e8ffb9f818 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期五, 26 七月 2024 22:34:44 +0800
Subject: [PATCH] 电磁锁报警查询提交

---
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java |  156 +++++++++++++++++++++++++++-------------------------
 1 files changed, 81 insertions(+), 75 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 f525c5c..d3d2fbd 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
@@ -104,8 +104,6 @@
     @Value("${syCar.password}")
     private String password;
 
-    private Timer lockStateTimer;
-
     @PostConstruct
     public void init(){
         ardSyCarController = this;
@@ -155,7 +153,7 @@
         //鍒犻櫎缁撴潫鏃堕棿涓簄ull鐨勮褰�
         int result = ardTankAbnormalParkAlarmService.deleteArdTankAbnormalParkAlarmByEndTime();
 
-        this.lockStateTimer = new Timer();//瀹氭椂鑾峰彇鍚勪釜閿佺殑鐘舵��
+        Timer lockStateTimer = new Timer();//瀹氭椂鑾峰彇鍚勪釜閿佺殑鐘舵��
         TimerTask lockStateTask =new TimerTask(){
             @Override
             public void run(){
@@ -180,7 +178,7 @@
 
                         List<ArdTankLock> result = ardTankLockService.getArdTankLockAll();//鏌ヨ鍏ㄩ儴鐢电閿�
                         for(ArdTankLock ardTankLock : result){
-                            Thread LockThread = new Thread(finalSyURL){
+                            Thread lockThread = new Thread(finalSyURL){
                                 @Override
                                 public void run() {
                                     String lockNumHead = ardTankLock.getLockNum().substring(0,2);
@@ -197,9 +195,13 @@
                                     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);
+                                    PositionContainer.getCarThreadMap().remove(ardTankLock.getCarId());//鍙戦�佸畬锛屼粠瀹瑰櫒鍘婚櫎
                                 }
                             };
-                            LockThread.start();
+                            if(PositionContainer.getCarThreadMap().get(ardTankLock.getCarId()) != null){//瀹瑰櫒涓棤绾跨▼锛屾斁鍏ュ鍣�
+                                PositionContainer.getCarThreadMap().put(ardTankLock.getCarId(),lockThread);
+                            }
+                            lockThread.start();
                         }
                     }
                 };
@@ -214,80 +216,84 @@
         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 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);
+                        String nowYearHex = Integer.toHexString(Integer.parseInt(nowYear));
+                        if(nowYearHex.length() == 1){
+                            nowYearHex = "0" + nowYearHex;
                         }
-                    };
-                    LockThread.start();
+                        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);
+                        PositionContainer.getCarThreadMap().remove(ardTankLock.getCarId());//鍙戦�佸畬锛屼粠瀹瑰櫒鍘婚櫎
+                    }
+                };
+                if(PositionContainer.getCarThreadMap().get(ardTankLock.getCarId()) != null){//瀹瑰櫒涓棤绾跨▼锛屾斁鍏ュ鍣�
+                    PositionContainer.getCarThreadMap().put(ardTankLock.getCarId(),lockThread);
                 }
+                lockThread.start();
+            }
             }
         };
         lockCheckTimeTimer.scheduleAtFixedRate(lockCheckTimeTask,date,7000);
@@ -316,7 +322,7 @@
         }
 
 
-        Timer alarmTimer = new Timer();//瀹氭椂鑾峰彇鎶ヨ
+        /*Timer alarmTimer = new Timer();//瀹氭椂鑾峰彇鎶ヨ
         TimerTask alarmTask = new TimerTask(){
             @Override
             public void run() {
@@ -329,7 +335,7 @@
                 alarmThread.start();
             }
         };
-        alarmTimer.scheduleAtFixedRate(alarmTask,date,3000);
+        alarmTimer.scheduleAtFixedRate(alarmTask,date,3000);*/
 
     }
 

--
Gitblit v1.9.3