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