Browse Source

:sparkles: 岸电接口对接拿取实时数据

lag 1 year ago
parent
commit
bddf0ed6f2

+ 5 - 0
src/main/java/com/shcd/controller/ShorePowerController.java

@@ -617,9 +617,14 @@ public class ShorePowerController {
     String platformID = (String) tokenData.get("PlatformID");
     JSONObject data = new JSONObject();
     JSONObject berthInfo = new JSONObject();
+    LocalDateTime now = LocalDateTime.now();
+    LocalDateTime oneHourAgo = now.minusHours(12);
+    DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
     berthInfo.put("realName", realName);
     berthInfo.put("page", page);
     berthInfo.put("limit", limit);
+    berthInfo.put("startTime", formatter.format(oneHourAgo));
+    berthInfo.put("endTime", formatter.format(now));
     data.put("userBerthRecordInfo", berthInfo);
     JSONObject deviceRequest = new JSONObject();
     deviceRequest.put("PlatformID", platformID);

+ 2 - 0
src/main/java/com/shcd/enums/GhjgPortThreeUrl.java

@@ -38,6 +38,8 @@ public enum GhjgPortThreeUrl {
   FILL_IN_THE_BERTHS_MANUALLY(
       "http://106.15.62.234:6060/shorepower/v1/query_userBerth_record_info",
       "3.12手动填报泊位(月度)信息查询"),
+  PROXY_FILL_IN_THE_BERTHS_MANUALLY("172.31.233.22:8092/shorePowerApi/query_userBerth_record_info",
+      "3.12手动填报泊位(月度)信息查询"),
   TOKEN_KEY("1234567890abcdef", "岸电token密钥");
 
   String url;

+ 706 - 0
src/main/java/com/shcd/scheduling/ShorePowerScheduler.java

@@ -0,0 +1,706 @@
+package com.shcd.scheduling;
+
+import cn.hutool.http.HttpRequest;
+import cn.hutool.http.HttpUtil;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.alibaba.fastjson.serializer.SerializerFeature;
+import com.google.common.collect.Maps;
+import com.shanghaigeography.entity.ResultMsg;
+import com.shanghaigeography.eum.ResultState;
+import com.shcd.entity.ShorePowerBerthInfo;
+import com.shcd.entity.ShorePowerBlberthmonthuse;
+import com.shcd.entity.ShorePowerChdevicefbo;
+import com.shcd.entity.ShorePowerConnRecordInfo;
+import com.shcd.entity.ShorePowerDeviceInfo;
+import com.shcd.entity.ShorePowerDeviceStatusInfo;
+import com.shcd.entity.ShorePowerPortInfo;
+import com.shcd.enums.GhjgPortThreeUrl;
+import com.shcd.service.*;
+import com.shcd.utils.secret.Encodes;
+import com.xxl.job.core.biz.model.ReturnT;
+import com.xxl.job.core.handler.annotation.XxlJob;
+import java.nio.charset.StandardCharsets;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import javax.annotation.PostConstruct;
+import javax.annotation.Resource;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.scheduling.annotation.Scheduled;
+import org.springframework.stereotype.Component;
+import org.springframework.util.CollectionUtils;
+import org.springframework.web.bind.annotation.RequestBody;
+
+@Component
+@Slf4j
+public class ShorePowerScheduler {
+
+  @Resource
+  private IShorePowerDeviceInfoService deviceInfoService;
+
+  @Resource
+  private IShorePowerBerthInfoService berthInfoService;
+
+  @Resource
+  private IShorePowerPortInfoService portInfoService;
+
+  @Resource
+  private IShorePowerConnRecordInfoService connRecordInfoService;
+
+  @Resource
+  private IShorePowerDeviceStatusInfoService deviceStatusInfoService;
+
+  @Resource
+  ShorePowerBlberthmonthuseService shorePowerBlberthmonthuseService;
+
+  @Resource
+  ShorePowerChdevicefboService shorePowerChdevicefboService;
+
+  ExecutorService service = Executors.newFixedThreadPool(2);
+
+//  @Scheduled(cron = "0 0 0/1 * * ? ")
+//    @Scheduled(cron = "0 0/1 * * * ?")
+  public void executeShorePowerScheduler() {
+    try {
+      service.execute(this::getConnRecordInfo);
+      service.execute(this::getUserBerthRecordInfo);
+    } catch (Exception e) {
+      log.error("执行出错,原因=====>{}", e.getMessage());
+    }
+  }
+
+  public String getToken() {
+    String result = null;
+    String token = null;
+    try {
+      JSONObject jsonObject = new JSONObject();
+      jsonObject.put("Sig", "59962D299728C732F772AD9CDE6A9456");
+      jsonObject.put("PlatformID", "425009768");
+      jsonObject.put("Data",
+          "/J9njgV+VvzgibMjaU4c0HH+Zbr9n5DRkJkfxLy0Z8agH7kzqKIbtm97MilBq0XaMbHfhxW+Vwd/JqfFVnvSbA==");
+      jsonObject.put("TimeStamp", "16880151424323");
+      jsonObject.put("Seq", "0001");
+      result = HttpUtil.createPost(GhjgPortThreeUrl.PROXY_SHORE_POWER.getUrl())
+          .setConnectionTimeout(3600000)
+          .setReadTimeout(3600000)
+          .header("Content-Type", "application/json")
+          .body(jsonObject.toString())
+          .charset("UTF-8").execute().body();
+      JSONObject resultJsonObject = JSONObject.parseObject(result);
+      String returnData = (String) resultJsonObject.get("Data");
+      token = new String(Encodes.aesDecrypt(
+          Encodes.decodeBase64(returnData),
+          GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+          GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+      log.info("岸电数据对接token解码后的结果为:{}", JSONObject.toJSONString(token));
+    } catch (Exception e) {
+      log.error("岸电数据对接token接口调用失败! ===>原因:{}",
+          JSONObject.toJSONString(e.getMessage()));
+      return new ResultMsg<String>().setCode(ResultState.ERROR).setMsg("调用失败")
+          .setData(JSONObject.toJSONString(e.getMessage())).toJSON();
+    }
+    return new ResultMsg<String>().setCode(ResultState.SUCCESS).setMsg("调用成功")
+        .setData(JSON.toJSONString(token)).toJSON();
+  }
+
+
+   public void getUserBerthRecordInfo() {
+    try {
+//      String realName = (String) map.get("realName");
+//      String page = (String) map.get("current");
+//      String limit = (String) map.get("size");
+      String realName = "";
+      String page = "1";
+      String limit = "500";
+      String result = executeUserBerthRecordInfoUrl(realName, page, limit);
+      log.info("3.12手动填报泊位(月度)信息查询 接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data).toLowerCase());
+        JSONArray jsonArray = (JSONArray) JSONObject.parse(data.toLowerCase());
+        log.info("records  ====>{}", jsonArray);
+        String arrayJSON = JSONObject.toJSONString(jsonArray, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerChdevicefbo> chdevicefboList = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerChdevicefbo chdevicefbo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerChdevicefbo.class);
+          chdevicefboList.add(chdevicefbo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(chdevicefboList));
+        List<ShorePowerBlberthmonthuse> subList = new ArrayList<>();
+        chdevicefboList.forEach(x -> {
+          log.info("==============> 泊位本月使用情况数据:{}",
+              JSONObject.toJSONString(x.getUseMonthList()));
+          if (!CollectionUtils.isEmpty(x.getUseMonthList())) {
+            subList.addAll(x.getUseMonthList());
+          }
+        });
+        chdevicefboList.forEach(x -> shorePowerChdevicefboService.saveOrUpdate(x));
+        subList.forEach(x -> shorePowerBlberthmonthuseService.saveOrUpdate(x));
+        log.info("操作完成,共有{}条数据,其中子集合的数据有:{}条", chdevicefboList.size(),
+            subList.size());
+      }
+    } catch (Exception e) {
+      e.printStackTrace();
+    }
+  }
+
+
+  //  @Scheduled(cron = "0 0 0/1 * * ? ")
+  public void getConnRecordInfo() {
+    try {
+//      JSONObject map = JSONObject.parseObject(params);
+//      String portId = (String) map.get("portId");
+//      String deviceId = (String) map.get("deviceId");
+//      String berthId = (String) map.get("berthId");
+//      String page = (String) map.get("current");
+//      String limit = (String) map.get("size");
+      String portId = "";
+      String deviceId = "";
+      String berthId = "";
+      String page = "1";
+      String limit = "500";
+      String result = executeConnRecordInfoUrl(portId, deviceId, berthId, page, limit);
+      log.info("连船记录信息查询查询接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data));
+        JSONObject dataJsonObject = (JSONObject) JSONObject.parse(data.toLowerCase());
+        JSONArray records = (JSONArray) dataJsonObject.get("records");
+        log.info("records  ====>{}", records);
+        String arrayJSON = JSONObject.toJSONString(records, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerConnRecordInfo> connRecordInfos = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerConnRecordInfo connRecordInfo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerConnRecordInfo.class);
+          connRecordInfos.add(connRecordInfo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(connRecordInfos));
+//        connRecordInfos.forEach(x -> connRecordInfoService.saveOrUpdate(x));
+//        connRecordInfoService.saveOrUpdateBatch(connRecordInfos);
+        for (ShorePowerConnRecordInfo connRecordInfo : connRecordInfos) {
+          connRecordInfoService.saveOrUpdate(connRecordInfo);
+        }
+        log.info("操作完成,共有{}条数据", connRecordInfos.size());
+//        connRecordInfoService.saveBatch(connRecordInfos);
+      }
+    } catch (Exception e) {
+      e.printStackTrace();
+    }
+  }
+
+  @Scheduled(cron = "0 0/1 * * * ?")
+  public void logScheduled() {
+    log.info("schedule is starting");
+  }
+
+  @Autowired
+  private SpStatementShipUsageMonthService spStatementShipUsageMonthService;
+
+  //@Scheduled(cron = "")
+  @PostConstruct
+  public void makeShangHaiShorePowerUsageRecord() {
+    spStatementShipUsageMonthService.makeShangHaiShorePowerUsageRecord();
+  }
+
+  @XxlJob("connectorStatusInfo")
+  public ReturnT<String> getConnectorStatusInfo(String params) {
+    try {
+      JSONObject map = JSONObject.parseObject(params);
+      String portId = (String) map.get("portId");
+      String deviceId = (String) map.get("deviceId");
+      String platformId = (String) map.get("platformId");
+      String operatorId = (String) map.get("operatorId");
+      String page = (String) map.get("current");
+      String limit = (String) map.get("size");
+      String result = executeConnectorStatusInfoUrl(portId, deviceId, platformId, operatorId, page,
+          limit);
+      log.info("岸电设备接口状态信息查询接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data));
+        JSONObject dataJsonObject = (JSONObject) JSONObject.parse(data.toLowerCase());
+        JSONArray records = (JSONArray) dataJsonObject.get("records");
+        log.info("records  ====>{}", records);
+        String arrayJSON = JSONObject.toJSONString(records, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerDeviceStatusInfo> deviceStatusInfos = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerDeviceStatusInfo deviceStatusInfo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerDeviceStatusInfo.class);
+          deviceStatusInfos.add(deviceStatusInfo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(deviceStatusInfos));
+//        deviceStatusInfos.forEach(x -> deviceStatusInfoService.saveOrUpdate(x));
+//        deviceStatusInfoService.saveOrUpdateBatch(deviceStatusInfos);
+        for (ShorePowerDeviceStatusInfo deviceStatusInfo : deviceStatusInfos) {
+          deviceStatusInfoService.saveOrUpdate(deviceStatusInfo);
+        }
+        log.info("操作完成,共有{}条数据", deviceStatusInfos.size());
+//        deviceStatusInfoService.saveBatch(deviceStatusInfos);
+      }
+    } catch (Exception e) {
+      return ReturnT.FAIL;
+    }
+    return ReturnT.SUCCESS;
+  }
+
+
+  @XxlJob("portInfo")
+  public ReturnT<String> getPortInfo(String params) {
+    try {
+      JSONObject map = JSONObject.parseObject(params);
+      String portId = (String) map.get("portId");
+      String page = (String) map.get("current");
+      String limit = (String) map.get("size");
+      String result = executePortInfoUrl(portId, page, limit);
+      log.info("长航 - 港口信息设备查询接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data));
+        JSONObject dataJsonObject = (JSONObject) JSONObject.parse(data.toLowerCase());
+        JSONArray records = (JSONArray) dataJsonObject.get("records");
+        log.info("records  ====>{}", records);
+        String arrayJSON = JSONObject.toJSONString(records, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerPortInfo> portInfoList = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerPortInfo portInfo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerPortInfo.class);
+          portInfoList.add(portInfo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(portInfoList));
+//        portInfoList.forEach(x -> portInfoService.saveOrUpdate(x));
+//        portInfoService.saveOrUpdateBatch(portInfoList);
+        for (ShorePowerPortInfo portInfo : portInfoList) {
+          portInfoService.saveOrUpdate(portInfo);
+        }
+        log.info("操作完成,共有{}条数据", portInfoList.size());
+      }
+    } catch (Exception e) {
+      e.printStackTrace();
+      return ReturnT.FAIL;
+    }
+    return ReturnT.SUCCESS;
+  }
+
+
+  @XxlJob("berthInfo")
+  public ReturnT<String> getBerthInfo(String params) {
+    try {
+      JSONObject map = JSONObject.parseObject(params);
+      String portId = (String) map.get("portId");
+      String berthId = (String) map.get("berthId");
+      String page = (String) map.get("current");
+      String limit = (String) map.get("size");
+      String result = executeBerthInfoUrl(portId, berthId, page, limit);
+      log.info("长航 - 泊位信息设备查询接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data).toLowerCase());
+        JSONObject dataJsonObject = (JSONObject) JSONObject.parse(data.toLowerCase());
+        JSONArray records = (JSONArray) dataJsonObject.get("records");
+        log.info("records  ====>{}", records);
+        String arrayJSON = JSONObject.toJSONString(records, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerBerthInfo> berthInfoList = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerBerthInfo deviceInfo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerBerthInfo.class);
+          berthInfoList.add(deviceInfo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(berthInfoList));
+        berthInfoList.forEach(x -> berthInfoService.saveOrUpdate(x));
+        log.info("操作完成,共有{}条数据", berthInfoList.size());
+      }
+    } catch (Exception e) {
+      e.printStackTrace();
+      return ReturnT.FAIL;
+    }
+    return ReturnT.SUCCESS;
+  }
+
+  @XxlJob("deviceInfo")
+  public ReturnT<String> getDeviceInfo(String params) {
+    try {
+      JSONObject map = JSONObject.parseObject(params);
+      String deviceId = (String) map.get("deviceId");
+      String berthId = (String) map.get("berthId");
+      String page = (String) map.get("current");
+      String limit = (String) map.get("size");
+      String result = executeDeviceInfoUrl(deviceId, berthId, page, limit);
+      log.info("长航 - 设备信息设备查询接口调用成功! ===>返回结果:{}",
+          JSONObject.toJSONString(result));
+      JSONObject jsonObject = JSONObject.parseObject(result);
+      if (0 == ((int) jsonObject.get("Ret"))) {
+        String lightData = (String) jsonObject.get("Data");
+        String data = new String(Encodes.aesDecrypt(
+            Encodes.decodeBase64(lightData),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+        log.info("==============> 业务数据:{}", JSONObject.toJSONString(data).toLowerCase());
+        JSONObject dataJsonObject = (JSONObject) JSONObject.parse(data.toLowerCase());
+        JSONArray records = (JSONArray) dataJsonObject.get("records");
+        log.info("records  ====>{}", records);
+        String arrayJSON = JSONObject.toJSONString(records, SerializerFeature.WriteClassName);
+        List<JSONObject> JSONObjectList = JSONObject.parseArray(arrayJSON,
+            JSONObject.class);
+        List<ShorePowerDeviceInfo> deviceInfoList = new ArrayList<>();
+        JSONObjectList.forEach(x -> {
+          ShorePowerDeviceInfo deviceInfo = JSONObject.parseObject(JSON.toJSONString(x),
+              ShorePowerDeviceInfo.class);
+          deviceInfo.setIs_jcbg(
+              deviceInfo.getIs_constructionspecification_jcbg());
+          deviceInfoList.add(deviceInfo);
+        });
+        log.info("==============> 业务转换为港航数据:{}",
+            JSONObject.toJSONString(deviceInfoList));
+        deviceInfoList.forEach(x -> deviceInfoService.saveOrUpdate(x));
+        log.info("操作完成,共有{}条数据", deviceInfoList.size());
+      }
+    } catch (Exception e) {
+      e.printStackTrace();
+      return ReturnT.FAIL;
+    }
+    return ReturnT.SUCCESS;
+  }
+
+  private String executeConnRecordInfoUrl(String portId, String deviceId, String berthId,
+      String page, String limit) {
+    try {
+      JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+      JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+      String accessToken = (String) tokenData.get("AccessToken");
+      String platformID = (String) tokenData.get("PlatformID");
+      JSONObject data = new JSONObject();
+      JSONObject berthInfo = new JSONObject();
+      LocalDateTime now = LocalDateTime.now();
+      LocalDateTime oneHourAgo = now.minusHours(24);
+      DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
+      berthInfo.put("startTime", formatter.format(oneHourAgo));
+      berthInfo.put("endTime", formatter.format(now));
+      berthInfo.put("portId", portId);
+      berthInfo.put("deviceId", deviceId);
+      berthInfo.put("berthId", berthId);
+      berthInfo.put("page", page);
+      berthInfo.put("limit", limit);
+      data.put("connRecordInfo", berthInfo);
+      JSONObject deviceRequest = new JSONObject();
+      deviceRequest.put("PlatformID", platformID);
+      deviceRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+      deviceRequest.put("Seq", "0001");
+      deviceRequest.put("Data", data);
+      JSONObject sss = (JSONObject) deviceRequest.get("Data");
+      String mvData = Encodes.encodeBase64(
+          Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+              GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+              GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+      deviceRequest.put("Data", mvData);
+      Map<String, String> param = Maps.newLinkedHashMap();
+      param.put("PlatformID", deviceRequest.getString("PlatformID"));
+      param.put("Data", deviceRequest.getString("Data"));
+      param.put("TimeStamp", deviceRequest.getString("TimeStamp"));
+      param.put("Seq", deviceRequest.getString("Seq"));
+      String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+      param.put("Sig", reqSign);
+      log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+      HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.PROXY_QUERY_CONNRECORD_INFO.getUrl());
+      Map<String, String> headers = new HashMap<>();
+      headers.put("Authorization", "Bearer" + " " + accessToken);
+      headers.put("Content-Type", "application/json;charset=utf-8");
+      post.addHeaders(headers);
+      return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+    } catch (Exception e) {
+      log.error("=====> 调用接口异常:{}", e.getMessage());
+      return e.getMessage();
+    }
+  }
+
+  private String executeConnectorStatusInfoUrl(String portId, String deviceId, String platformId,
+      String operatorId, String page, String limit) {
+    JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+    JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+    String accessToken = (String) tokenData.get("AccessToken");
+    String platformID = (String) tokenData.get("PlatformID");
+    JSONObject data = new JSONObject();
+    JSONObject berthInfo = new JSONObject();
+    berthInfo.put("portId", portId);
+    berthInfo.put("deviceId", deviceId);
+    berthInfo.put("platformId", platformId);
+    berthInfo.put("operatorId", operatorId);
+    berthInfo.put("page", page);
+    berthInfo.put("limit", limit);
+    data.put("connectorStatusInfo", berthInfo);
+    JSONObject deviceRequest = new JSONObject();
+    deviceRequest.put("PlatformID", platformID);
+    deviceRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+    deviceRequest.put("Seq", "0001");
+    deviceRequest.put("Data", data);
+    JSONObject sss = (JSONObject) deviceRequest.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    deviceRequest.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", deviceRequest.getString("PlatformID"));
+    param.put("Data", deviceRequest.getString("Data"));
+    param.put("TimeStamp", deviceRequest.getString("TimeStamp"));
+    param.put("Seq", deviceRequest.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    param.put("Sig", reqSign);
+    log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+    HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.QUERY_CONNECTOR_STATUS_INFO.getUrl());
+    Map<String, String> headers = new HashMap<>();
+    headers.put("Authorization", "Bearer" + " " + accessToken);
+    headers.put("Content-Type", "application/json;charset=utf-8");
+    post.addHeaders(headers);
+    return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+  }
+
+
+  private String executeBerthInfoUrl(String portId, String berthId, String page, String limit) {
+    JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+    JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+    String accessToken = (String) tokenData.get("AccessToken");
+    String platformID = (String) tokenData.get("PlatformID");
+    JSONObject data = new JSONObject();
+    JSONObject berthInfo = new JSONObject();
+    berthInfo.put("portId", portId);
+    berthInfo.put("berthId", berthId);
+    berthInfo.put("page", page);
+    berthInfo.put("limit", limit);
+    data.put("berthRequest", berthInfo);
+    JSONObject deviceRequest = new JSONObject();
+    deviceRequest.put("PlatformID", platformID);
+    deviceRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+    deviceRequest.put("Seq", "0001");
+    deviceRequest.put("Data", data);
+    JSONObject sss = (JSONObject) deviceRequest.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    deviceRequest.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", deviceRequest.getString("PlatformID"));
+    param.put("Data", deviceRequest.getString("Data"));
+    param.put("TimeStamp", deviceRequest.getString("TimeStamp"));
+    param.put("Seq", deviceRequest.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    param.put("Sig", reqSign);
+    log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+    HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.CHANG_HANG_BERTH_INFO.getUrl());
+    Map<String, String> headers = new HashMap<>();
+    headers.put("Authorization", "Bearer" + " " + accessToken);
+    headers.put("Content-Type", "application/json;charset=utf-8");
+    post.addHeaders(headers);
+    return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+  }
+
+  private String executeDeviceInfoUrl(String deviceId, String berthId, String page, String limit) {
+    JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+    JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+    String accessToken = (String) tokenData.get("AccessToken");
+    String platformID = (String) tokenData.get("PlatformID");
+    JSONObject data = new JSONObject();
+    JSONObject berthInfo = new JSONObject();
+    berthInfo.put("deviceId", deviceId);
+    berthInfo.put("berthId", berthId);
+    berthInfo.put("page", page);
+    berthInfo.put("limit", limit);
+    data.put("deviceRequest", berthInfo);
+    JSONObject deviceRequest = new JSONObject();
+    deviceRequest.put("PlatformID", platformID);
+    deviceRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+    deviceRequest.put("Seq", "0001");
+    deviceRequest.put("Data", data);
+    JSONObject sss = (JSONObject) deviceRequest.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    deviceRequest.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", deviceRequest.getString("PlatformID"));
+    param.put("Data", deviceRequest.getString("Data"));
+    param.put("TimeStamp", deviceRequest.getString("TimeStamp"));
+    param.put("Seq", deviceRequest.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    param.put("Sig", reqSign);
+    log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+    HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.CHANG_HANG_DEVICE_INFO.getUrl());
+    Map<String, String> headers = new HashMap<>();
+    headers.put("Authorization", "Bearer" + " " + accessToken);
+    headers.put("Content-Type", "application/json;charset=utf-8");
+    post.addHeaders(headers);
+    return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+  }
+
+  private String executePortInfoUrl(String portId, String page, String limit) {
+    JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+    JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+    String accessToken = (String) tokenData.get("AccessToken");
+    String platformID = (String) tokenData.get("PlatformID");
+    JSONObject data = new JSONObject();
+    JSONObject berthInfo = new JSONObject();
+    berthInfo.put("portId", portId);
+    berthInfo.put("page", page);
+    berthInfo.put("limit", limit);
+    data.put("portRequest", berthInfo);
+    JSONObject portRequest = new JSONObject();
+    portRequest.put("PlatformID", platformID);
+    portRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+    portRequest.put("Seq", "0001");
+    portRequest.put("Data", data);
+    JSONObject sss = (JSONObject) portRequest.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    portRequest.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", portRequest.getString("PlatformID"));
+    param.put("Data", portRequest.getString("Data"));
+    param.put("TimeStamp", portRequest.getString("TimeStamp"));
+    param.put("Seq", portRequest.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    param.put("Sig", reqSign);
+    log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+    HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.CHANG_HANG_PORT_INFO.getUrl());
+    Map<String, String> headers = new HashMap<>();
+    headers.put("Authorization", "Bearer" + " " + accessToken);
+    headers.put("Content-Type", "application/json;charset=utf-8");
+    post.addHeaders(headers);
+    return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+  }
+
+  private String executeUserBerthRecordInfoUrl(String realName, String page, String limit) {
+    JSONObject tokenJsonObject = JSONObject.parseObject(getToken());
+    JSONObject tokenData = JSONObject.parseObject((String) tokenJsonObject.get("data"));
+    String accessToken = (String) tokenData.get("AccessToken");
+    String platformID = (String) tokenData.get("PlatformID");
+    JSONObject data = new JSONObject();
+    JSONObject berthInfo = new JSONObject();
+    LocalDateTime now = LocalDateTime.now();
+    LocalDateTime oneHourAgo = now.minusHours(12);
+    DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
+    berthInfo.put("realName", realName);
+    berthInfo.put("page", page);
+    berthInfo.put("limit", limit);
+    berthInfo.put("startTime", formatter.format(oneHourAgo));
+    berthInfo.put("endTime", formatter.format(now));
+    data.put("userBerthRecordInfo", berthInfo);
+    JSONObject deviceRequest = new JSONObject();
+    deviceRequest.put("PlatformID", platformID);
+    deviceRequest.put("TimeStamp", String.valueOf(System.currentTimeMillis()));
+    deviceRequest.put("Seq", "0001");
+    deviceRequest.put("Data", data);
+    JSONObject sss = (JSONObject) deviceRequest.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    deviceRequest.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", deviceRequest.getString("PlatformID"));
+    param.put("Data", deviceRequest.getString("Data"));
+    param.put("TimeStamp", deviceRequest.getString("TimeStamp"));
+    param.put("Seq", deviceRequest.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    param.put("Sig", reqSign);
+    log.info("=====> 入参:{}", JSONObject.toJSONString(param));
+    HttpRequest post = HttpUtil.createPost(GhjgPortThreeUrl.PROXY_FILL_IN_THE_BERTHS_MANUALLY.getUrl());
+    Map<String, String> headers = new HashMap<>();
+    headers.put("Authorization", "Bearer" + " " + accessToken);
+    headers.put("Content-Type", "application/json;charset=utf-8");
+    post.addHeaders(headers);
+    return post.body(JSONObject.toJSONString(param)).setReadTimeout(3600000).execute().body();
+  }
+
+
+  public static void main(String[] args) {
+    JSONObject data = new JSONObject();
+    JSONObject jsonObject = new JSONObject();
+    JSONObject portRequest = new JSONObject();
+    portRequest.put("limit", "20");
+    portRequest.put("page", "1");
+    portRequest.put("portId", "0001");
+    data.put("portRequest", portRequest);
+    jsonObject.put("PlatformID", "425009768");
+    jsonObject.put("Data", data);
+    jsonObject.put("TimeStamp", "16880151424323");
+    jsonObject.put("Seq", "001");
+    JSONObject sss = (JSONObject) jsonObject.get("Data");
+    String mvData = Encodes.encodeBase64(
+        Encodes.aesEncrypt(sss.toString().getBytes(StandardCharsets.UTF_8),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+            GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()));
+    jsonObject.put("Data", mvData);
+    Map<String, String> param = Maps.newLinkedHashMap();
+    param.put("PlatformID", jsonObject.getString("PlatformID"));
+    param.put("Data", jsonObject.getString("Data"));
+    param.put("TimeStamp", jsonObject.getString("TimeStamp"));
+    param.put("Seq", jsonObject.getString("Seq"));
+    String reqSign = Encodes.sign(param, GhjgPortThreeUrl.TOKEN_KEY.getUrl());
+    jsonObject.put("Sig", reqSign);
+    System.out.println(jsonObject);
+
+    String result = new String(Encodes.aesDecrypt(
+        Encodes.decodeBase64(
+            "gbc4kk0TAbgF+OyUUsVxR3w8cuJzO2d9KH+1wVvB5gyJSYOucNO4UEmyToekslu+BoGIyRH/2FCTMem/oQI7WHlwGPUbETN0rQ2JBF+S/p0="),
+        GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes(),
+        GhjgPortThreeUrl.TOKEN_KEY.getUrl().getBytes()), StandardCharsets.UTF_8);
+    System.out.println(result);
+  }
+}