From c3ec70d2bd1ebd2421d2fa3e85c1ac43e2322ea6 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期一, 22 七月 2024 14:44:52 +0800 Subject: [PATCH] 电子围栏加入类型提交 --- ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java | 439 ++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 305 insertions(+), 134 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..ce166a3 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,33 @@ 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.common.utils.uuid.IdUtils; import com.ruoyi.sy.domain.ArdSyCarLock; import com.ruoyi.sy.domain.ArdSyCarRtu; +import com.ruoyi.sy.domain.ArdTankLock; +import com.ruoyi.sy.domain.ArdTankLockState; 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.*; +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 okhttp3.OkHttpClient; +import okhttp3.Request; +import okhttp3.Response; +import org.apache.commons.codec.digest.DigestUtils; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; import org.eclipse.paho.client.mqttv3.MqttException; +import java.io.IOException; import java.math.BigDecimal; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.UUID; +import java.text.SimpleDateFormat; +import java.util.*; /** * <p>Description: </p> @@ -38,16 +47,15 @@ * @author chencq * @version 1.0 */ -@Slf4j(topic = "mqttCar") public class PushClientImplSerialPort extends PushClient implements Runnable { -// private static final Log log = LogFactory.getLog(PushClientImplPosition.class); + private static final Log log = LogFactory.getLog(PushClientImplSerialPort.class); - private String ip; + private static String ip; - private String userId; + private static String userId; - private String password; + private static String password; public PushClientImplSerialPort(String ip, String userId, String password) { this.ip = ip; @@ -96,8 +104,238 @@ */ }else if("0401".equals(pushMsg.getCmd())) {//閫忎紶娑堟伅 Map<String,Object> dataMap = pushMsg.getJsonMap(); - String carName = MapUtil.getStrVal(dataMap, "carName","");//鑾峰彇杞︾墝鍙� + //String carName = MapUtil.getStrVal(dataMap, "carName","");//鑾峰彇杞︾墝鍙� //log.error(String.format(" ---->鏀跺埌閫忎紶鏁版嵁:%s",JSON.toJSONString(dataMap))); + Thread thread = new Thread(){ + @Override + public void run() { + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date now = new Date(); + try { + String data = (String) dataMap.get("data"); + String lockNum = data.substring(0, 4); + String code = data.substring(4, 6); + if(code.equals("01")){//鍔熻兘鐮�01涓洪攣瀹炴椂鐘舵�� + String lockState = data.substring(6, 8); + String lockPositionState = data.substring(8, 10); + String lockShellState = data.substring(10, 12); + String restartState = data.substring(12, 14); + String batterVoltage = data.substring(14, 18); + String powerVoltage = data.substring(18, 22); + String time = data.substring(22, 34); + //璁$畻鏃堕棿 + String year = time.substring(0, 2); + String month = time.substring(2, 4); + String day = time.substring(4, 6); + String hour = time.substring(6, 8); + String minute = time.substring(8, 10); + String second = time.substring(10, 12); + + Integer yearNum = Integer.parseInt(year, 16); + if(yearNum <= 9){ + time = "200" + yearNum + "-"; + }else{ + time = "20" + yearNum + "-"; + } + + Integer monthNum = Integer.parseInt(month, 16); + if(monthNum <= 9){ + time = time + "0" + monthNum + "-"; + }else{ + time = time + monthNum + "-"; + } + + Integer dayNum = Integer.parseInt(day, 16); + if(dayNum <= 9){ + time = time + "0" + dayNum + " "; + }else{ + time = time + dayNum + " "; + } + + Integer hourNum = Integer.parseInt(hour, 16); + if(hourNum <= 9){ + time = time + "0" + hourNum + ":"; + }else{ + time = time + hourNum + ":"; + } + + Integer minuteNum = Integer.parseInt(minute, 16); + if(minuteNum <= 9){ + time = time + "0" + minuteNum + ":"; + }else{ + time = time + minuteNum + ":"; + } + + Integer secondNum = Integer.parseInt(second, 16); + if(secondNum <= 9){ + time = time + "0" + secondNum; + }else{ + time = time + secondNum; + } + + ArdTankLock ardTankLock = new ArdTankLock(); + ardTankLock.setLockNum(lockNum); + List<ArdTankLock> ardTankLockResult = ((ArdTankLockServiceImpl)SpringUtils.getBean("ardTankLockServiceImpl")).selectArdTankLockList(ardTankLock); + + if(ardTankLockResult.isEmpty()){//閿佹病鏈夊綍鍏ュ垯杩斿洖 + return; + } + + long cha = now.getTime() - sdf.parse(time).getTime(); + System.out.println("////////////////"); + System.out.println(time); + System.out.println(cha); + /*if(Math.abs(cha) >= 5 * 1000){ + //鏃堕棿鏍″噯 + String url = "http://" + ip + ":9999"; + String passwordMd5 = DigestUtils.md5Hex(password); + Map<String, Object> LogInResult = loginIn(url, userId, passwordMd5); + String sessionId = (String) LogInResult.get("sessionId"); + //鑾峰彇鏃堕棿骞舵媶鍒嗗勾鏈堟棩鏃跺垎绉� + String nowTime = sdf.format(now); + String nowYear = nowTime.substring(2,4); + System.out.println(nowYear); + String nowMonth = nowTime.substring(5,7); + System.out.println(nowMonth); + String nowDay = nowTime.substring(8,10); + System.out.println(nowDay); + String nowHour = nowTime.substring(11,13); + System.out.println(nowHour); + String nowMinute = nowTime.substring(14,16); + System.out.println(nowMinute); + String nowSecond = nowTime.substring(17,19); + System.out.println(nowSecond); + + String nowYearHex = Integer.toHexString(Integer.parseInt(nowYear)); + if(nowYearHex.length() == 1){ + nowYearHex = "0" + nowYearHex; + } + System.out.println(nowYearHex); + String nowMonthHex = Integer.toHexString(Integer.parseInt(nowMonth)); + if(nowMonthHex.length() == 1){ + nowMonthHex = "0" + nowMonthHex; + } + System.out.println(nowMonthHex); + String nowDayHex = Integer.toHexString(Integer.parseInt(nowDay)); + if(nowDayHex.length() == 1){ + nowDayHex = "0" + nowDayHex; + } + System.out.println(nowDayHex); + String nowHourHex = Integer.toHexString(Integer.parseInt(nowHour)); + if(nowHourHex.length() == 1){ + nowHourHex = "0" + nowHourHex; + } + System.out.println(nowHourHex); + String nowMinuteHex = Integer.toHexString(Integer.parseInt(nowMinute)); + if(nowMinuteHex.length() == 1){ + nowMinuteHex = "0" + nowMinuteHex; + } + System.out.println(nowMinuteHex); + String nowSecondHex = Integer.toHexString(Integer.parseInt(nowSecond)); + if(nowSecondHex.length() == 1){ + nowSecondHex = "0" + nowSecondHex; + } + System.out.println(nowSecondHex); + //16杩涘埗鏃堕棿 + String timeHex = nowYearHex + nowMonthHex + nowDayHex + nowHourHex + nowMinuteHex + nowSecondHex; + System.out.println(timeHex); + String lockNumHead = ardTankLockResult.get(0).getLockNum().substring(0,2); + String lockNumTail = ardTankLockResult.get(0).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)); + System.out.println(checkNum); + if(checkNum.length() == 1){ + checkNum = "0" + checkNum; + }else if(checkNum.length() > 2){ + checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length()); + } + System.out.println(checkNum); + String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "08" + timeHex + checkNum + "%22%7D"; + System.out.println(ardTankLock.getLockNum() + "08" + timeHex + checkNum); + sendCmd(url,userId,ardTankLockResult.get(0).getCarId(),199,"DataDownTransfer", paramsStr,sessionId); + }else{*/ + ArdTankLockState ardTankLockState = new ArdTankLockState(); + ardTankLockState.setId(IdUtils.simpleUUID()); + ardTankLockState.setLockId(ardTankLockResult.get(0).getId()); + ardTankLockState.setLockNum(lockNum); + switch (lockState) {//閿佽姱鐘舵�� + case "01": ardTankLockState.setLockState("寮�閿佺姸鎬�");break; + case "02": ardTankLockState.setLockState("鍏抽攣鐘舵��");break; + case "03": ardTankLockState.setLockState("寮傚父鐘舵��");break; + default: + break; + } + switch (lockPositionState) {//浣嶇疆鐘舵�� + case "01": ardTankLockState.setLockPositionState("姝e父");break; + case "02": ardTankLockState.setLockPositionState("寮傚父");break; + default: + break; + } + switch (lockShellState) {//澶栧3鐘舵�� + case "01": ardTankLockState.setLockShellState("姝e父");break; + case "02": ardTankLockState.setLockShellState("寮傚父");break; + default: + break; + } + switch (restartState) {//澶嶄綅鐘舵�� + case "01": ardTankLockState.setRestartState("寮�閿佺姸鎬�");break; + case "02": ardTankLockState.setRestartState("鍏抽攣鐘舵��");break; + default: + break; + } + Number batterVoltageNum = Integer.parseInt(batterVoltage,16) * 0.1; + String batterVoltageStr = String.valueOf(batterVoltageNum); + if(batterVoltageStr.length() > 4){ + batterVoltageStr = batterVoltageStr.substring(0,4); + } + if(batterVoltageStr.contains(".")){//鍥涜垗浜斿叆 + String decimalPart = batterVoltageStr.split("\\.")[1]; + if(Integer.parseInt(decimalPart) > 5){ + batterVoltageStr = batterVoltageStr.split("\\.")[0] + ".5"; + }else if(Integer.parseInt(decimalPart) <= 5){ + batterVoltageStr = batterVoltageStr.split("\\.")[0] + ".0"; + } + }else{ + batterVoltageStr = batterVoltageStr + ".0"; + } + ardTankLockState.setBatterVoltage(batterVoltageStr); + + + Number powerVoltageNum = Integer.parseInt(powerVoltage,16) * 0.1; + String powerVoltageStr = String.valueOf(powerVoltageNum); + if(powerVoltageStr.length() > 4){ + powerVoltageStr = powerVoltageStr.substring(0,4); + } + if(powerVoltageStr.contains(".")){//鍥涜垗浜斿叆 + String decimalPart = powerVoltageStr.split("\\.")[1]; + if(Integer.parseInt(decimalPart) > 5){ + powerVoltageStr = powerVoltageStr.split("\\.")[0] + ".5"; + }else if(Integer.parseInt(decimalPart) <= 5){ + powerVoltageStr = powerVoltageStr.split("\\.")[0] + ".0"; + } + }else{ + powerVoltageStr = powerVoltageStr + ".0"; + } + ardTankLockState.setPowerVoltage(powerVoltageStr); + + String uniqueMark = lockNum + "," + lockState + "," + lockPositionState + "," + lockShellState + + "," + restartState + "," + batterVoltageStr + "," + powerVoltageStr; + + ardTankLockState.setUploadTime(time); + ardTankLockState.setUniqueMark(uniqueMark); + ((ArdTankLockStateServiceImpl)SpringUtils.getBean("ardTankLockStateServiceImpl")).insertOrUpdateArdTankLockState(ardTankLockState); + + //} + } + }catch (Exception e){ + e.printStackTrace(); + return;//寮鸿浆澶辫触杩斿洖 + } + } + }; + thread.start(); /** * * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫 @@ -130,132 +368,65 @@ 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皝"); - } - } + public static Map<String,Object> loginIn(String syURL,String userId,String password){//鐧诲綍 + OkHttpClient okHttpClient = new OkHttpClient(); - //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)),"鏂藉皝"); - } - } - } - } - } - } - } - } + String passwordMd5 = DigestUtils.md5Hex(password); - 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; + Request request = new Request.Builder() + .url(syURL + "/gps-web/api/login.jsp?"+"password="+passwordMd5+"&userId="+userId+"&loginType=user&loginWay=interface&loginLang=zh_CN") + .build(); + Response response = null; try { - t = (new Date().getTime() - simpleDateFormat.parse(time).getTime())/1000; - } catch (Exception e) { + response = okHttpClient.newCall(request).execute(); + } catch (IOException e1) { + // TODO Auto-generated catch block + e1.printStackTrace(); + } + + response.headers(); //鍝嶅簲澶� + + okhttp3.ResponseBody responseBody = response.body(); + + try { + String message = responseBody.string();// 鍝嶅簲浣� + Map<String,Object> map = (Map<String, Object>) JSON.parse(message); + map.put("passwordMd5", passwordMd5); + //System.out.println(message); + return map; + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + return new HashMap(); + } + } + + public Map<String,Object> sendCmd(String syURL,String userId,String carId,Integer cmdId,String cmd,String paramsStr,String sessionId){ + OkHttpClient okHttpClient = new OkHttpClient(); + + Request request = new Request.Builder() + .url(syURL + "/gps-web/api/send_cmd.jsp?params="+paramsStr+"&userId="+userId+"&carId="+carId+"&cmdId="+cmdId+"&cmd="+cmd+"&sessionId="+sessionId) + .build(); + //System.out.println("url = " + syURL + "/gps-web/api/send_cmd.jsp?params="+paramsStr+"&userId="+userId+"&carId="+carId+"&cmdId="+cmdId+"&cmd="+cmd+"&sessionId="+sessionId); + Response response = null; + try { + response = okHttpClient.newCall(request).execute(); + } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } - Double velocityt = velocity + acceleration*t; - return velocityt; - }*/ + + okhttp3.ResponseBody responseBody = response.body(); + + try { + String message = responseBody.string();// 鍝嶅簲浣� + Map<String,Object> map = (Map<String, Object>) JSON.parse(message); + return map; + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + return new HashMap(); + } + } } -- Gitblit v1.9.3