From 57c673aa3e83677bcf5d30b4b45d06bae6609db8 Mon Sep 17 00:00:00 2001
From: liusuyi <1951119284@qq.com>
Date: 星期四, 08 八月 2024 16:14:40 +0800
Subject: [PATCH] 优化:获取会话
---
ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplSerialPort.java | 419 ++++++++++++++++++++++++++++++++++++++++-------------------
1 files changed, 285 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..798750f 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,17 @@
* @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;
+
+ private SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
public PushClientImplSerialPort(String ip, String userId, String password) {
this.ip = ip;
@@ -96,8 +106,216 @@
*/
}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");
+ if(data.length() %2 != 0){//闀垮害涓嶆槸鍋舵暟锛屽氨杩斿洖
+ return;
+ }
+
+ Integer sum = 0;
+ for(int i = 0;i <= data.length() - 4;i = i + 2){
+ String str = data.substring(i, i + 2);
+ sum = sum + Integer.parseInt(str, 16);
+ }//姹傚拰
+ String checkNum = data.substring(data.length() - 2, data.length());
+ String checkNumComputed = Integer.toHexString(sum).toUpperCase();//璁$畻鏍¢獙
+ //褰撴牎楠屾暟鎹ぇ浜�2涓瓧绗︼紝鎴彇鏈�鍚庝袱浣�
+ if(checkNumComputed.length() != 2){
+ checkNumComputed = checkNumComputed.substring(checkNumComputed.length() - 2,checkNumComputed.length());
+ }
+ if(!checkNum.equals(checkNumComputed)){//鏍¢獙涓嶉�氳繃锛屽氨杩斿洖
+ return;
+ }
+
+ 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 time = sdf.format(new Date());
+
+ ArdTankLock ardTankLock = new ArdTankLock();
+ ardTankLock.setLockNum(lockNum);
+ List<ArdTankLock> ardTankLockResult = ((ArdTankLockServiceImpl)SpringUtils.getBean("ardTankLockServiceImpl")).selectArdTankLockList(ardTankLock);
+
+ if(ardTankLockResult.isEmpty()){//閿佹病鏈夊綍鍏ュ垯杩斿洖
+ return;
+ }
+
+ 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;
+ case "04": 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);
+ }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;//寮鸿浆澶辫触杩斿洖
+ }
+ }
+ };
+ thread.start();
/**
*
* 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -130,132 +348,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