From 00c17a3a10a2856c847757e7021e60135b6ea894 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期六, 27 七月 2024 23:55:43 +0800 Subject: [PATCH] 电磁锁密码提交 --- ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java | 85 +++++++++++++++++++++++++++++++++++++++++- 1 files changed, 83 insertions(+), 2 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 ee4a60d..c88f32e 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 @@ -330,9 +330,90 @@ ardTankLockState.setUniqueMark(uniqueMark); ((ArdTankLockStateServiceImpl)SpringUtils.getBean("ardTankLockStateServiceImpl")).insertOrUpdateArdTankLockState(ardTankLockState); } - }/*else if(code.equals("06")){//鍔熻兘鐮�06涓洪攣鍘嗗彶鎶ヨ + }else if(code.equals("05")){//鍔熻兘鐮�05涓鸿鍙栭攣瀵嗙爜 + Set<String> passwordAndTimeSet = new HashSet(); + for(int i = 1;i <= 10;i++){ + String passwordAndTime = data.substring(6 + 24*(i - 1),6 + 24 * i); + passwordAndTimeSet.add(passwordAndTime);//鎷嗗垎鍑哄瘑鐮佸拰浣跨敤鏃堕棿 + } + if(passwordAndTimeSet.size() == 1){//鍏ㄩ儴涓哄垵濮嬪瘑鐮侊紝鍒欎粠鏂拌缃� + Set<String> passwordSet = new HashSet(); + while(passwordSet.size() != 10){ + String password = ""; + for(int i = 0;i <= 5;i++){ + password = password + String.valueOf(10 * Math.random()).split("\\.")[0]; + } + passwordSet.add(password); + } + if(PositionContainer.getCarLockPasswordMap().get(lockNum) == null){ + PositionContainer.getCarLockPasswordMap().put(lockNum,passwordSet); + } + }else{//鏌ョ湅鍝簺瀵嗙爜浣跨敤杩� + for(String passwordAndTime : passwordAndTimeSet){ + String time = passwordAndTime.substring(12,24); + if(!time.equals("FFFFFFFFFFFF")){ + String passwordHex = passwordAndTime.substring(0,12);//16杩涘埗瀵嗙爜 + String password = "";//瀹為檯瀵嗙爜 + for(int i = 0;i <= 10;i = i + 2){ + String passwordHexByte = passwordHex.substring(i, i+2); + password = password + passwordHexByte.split("")[1]; + } - }*/ + String useTimeHex = passwordAndTime.substring(12,24);//16杩涘埗鏃堕棿 + String yearHex = useTimeHex.substring(0, 2); + String monthHex = useTimeHex.substring(2, 4); + String dayHex = useTimeHex.substring(4, 6); + String hourHex = useTimeHex.substring(6, 8); + String minuteHex = useTimeHex.substring(8, 10); + String secondHex = useTimeHex.substring(10, 12); + + String useTime = ""; + Integer yearNum = Integer.parseInt(yearHex, 16); + if(yearNum <= 9){ + useTime = "200" + yearNum + "-"; + }else{ + useTime = "20" + yearNum + "-"; + } + + Integer monthNum = Integer.parseInt(monthHex, 16); + if(monthNum <= 9){ + useTime = useTime + "0" + monthNum + "-"; + }else{ + useTime = useTime + monthNum + "-"; + } + + Integer dayNum = Integer.parseInt(dayHex, 16); + if(dayNum <= 9){ + useTime = useTime + "0" + dayNum + " "; + }else{ + useTime = useTime + dayNum + " "; + } + + Integer hourNum = Integer.parseInt(hourHex, 16); + if(hourNum <= 9){ + useTime = useTime + "0" + hourNum + ":"; + }else{ + useTime = useTime + hourNum + ":"; + } + + Integer minuteNum = Integer.parseInt(minuteHex, 16); + if(minuteNum <= 9){ + useTime = useTime + "0" + minuteNum + ":"; + }else{ + useTime = useTime + minuteNum + ":"; + } + + Integer secondNum = Integer.parseInt(secondHex, 16); + if(secondNum <= 9){ + useTime = useTime + "0" + secondNum; + }else{ + useTime = useTime + secondNum; + } + ((ArdTankLockPasswordServiceImpl)SpringUtils.getBean("ardTankLockPasswordServiceImpl")).updateArdTankLockPasswordByLockNum(lockNum,password,useTime); + } + } + } + } }catch (Exception e){ e.printStackTrace(); return;//寮鸿浆澶辫触杩斿洖 -- Gitblit v1.9.3