jiangping
2025-03-11 293ac5014b831208f984d41cfec252ebe7a01774
server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
@@ -1,10 +1,9 @@
package com.doumee.core.haikang.model;
import com.alibaba.fastjson.JSONObject;
import com.doumee.config.SpringContextUtil;
import com.doumee.core.haikang.model.param.request.CarPictureRequest;
import com.doumee.core.haikang.model.param.request.FacePictureCheckRequest;
import com.doumee.core.haikang.service.HKService;
import com.doumee.core.utils.Constants;
import com.doumee.dao.business.model.InterfaceLog;
import com.doumee.service.business.InterfaceLogService;
import com.hikvision.artemis.sdk.ArtemisHttpUtil;
@@ -13,18 +12,14 @@
import org.apache.commons.lang3.StringUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.tomcat.util.bcel.Const;
import org.yaml.snakeyaml.scanner.Constant;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.InetSocketAddress;
import java.net.Proxy;
import java.net.URL;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
@Slf4j
@@ -34,11 +29,12 @@
   public static void main(String[] args) throws Exception {
      ArtemisConfig.host = "10.50.60.253";
      ArtemisConfig.appKey = "27786546";
      ArtemisConfig.appSecret = "kC5dohxU7CvEqgGhVt4R";
      ArtemisConfig.host = "10.50.250.253:1443";
      ArtemisConfig.appKey = "23154099";
      ArtemisConfig.appSecret = "88wFsg3xfn7o8QMsWEO2";
      HKConstants.https = "https://";
      CarPictureRequest param = new CarPictureRequest();
   /*   CarPictureRequest param = new CarPictureRequest();
      param.setPicUri( "HKIMG=/pic?0dd400=4c40ip-feo831-933*9o4=3=2109*2l0001893117*0t7=6*2ps==014b*=787d*069d70361-95754d-9*l108od0b192=001");
      param.setAswSyscode("3fa3e5e3-db3e-41ba-97fc-39c948778dfe");
      InputStream is = HKService.getCarPicture(param);
@@ -57,7 +53,11 @@
         outStream.close(); //写入数据
      } catch ( Exception e) {
         throw new RuntimeException(e);
      }
      }*/
      FacePictureCheckRequest param = new FacePictureCheckRequest();
      param.setFacePicUrl("http://10.50.250.253:8088/file/member/20241016/d0cded86-a55d-43be-bc01-4f628a1400cf.jpg");
      System.out.println(facePictureCheck(JSONObject.toJSONString(param)));
   }
   public static InterfaceLogService interfaceLogService = null;
@@ -79,9 +79,9 @@
   private static Map<String, String> getPath(String str) {
      final String getCamsApi = HKConstants.ARTEMIS_PATH  + str;
      Map<String, String> path = new HashMap<String, String>(2) {
         {
            put(HKConstants.https, getCamsApi);// 根据现场环境部署确认是http还是https
         }
      {
         put(HKConstants.https, getCamsApi);// 根据现场环境部署确认是http还是https
      }
      };
      return  path;
   }
@@ -246,6 +246,7 @@
         InputStream in = entity.getContent();
         return  in;
      }else{
         log.error("人脸下载出错");
         throw  new Exception("人脸下载出错");
      }
   }
@@ -303,6 +304,42 @@
         throw  new Exception("查询车辆抓拍图片下载出错");
      }
   }
   /**
    * 分页获取待办列表
    * @param body
    * @return
    */
   public static String getTodoListPage(Map<String, String> body)  throws  Exception{
      return startDoGetStringArtemis(HKConstants.InterfacePath.getTodoListPage,body);
   }
   /**
    *消防看板-4温湿度数据
    * @param body
    * @return
    */
   public static String temperatureHumidityDataStatistic(String body) {
      return startDoPostStringArtemisAdmin(HKConstants.InterfacePath.temperatureHumidityDataStatistic,body);
   }
   /**
    *消防看板-4获取区域用量排名-能耗看板
    * @param body
    * @return
    */
   public static String regionDataRanking(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.regionDataRanking,body);
   }
   /**
    *消防看板-4根据时间和时间维度获取园区能耗数据
    * @param body
    * @return
    */
   public static String energyTotal(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.energyTotal,body);
   }
   /**
    *   获取门禁点列表
    * @param body
@@ -369,15 +406,7 @@
      return  startDoPostStringArtemis(HKConstants.InterfacePath.visitCancel,body);
   }
   public static String startDoGetStringArtemis(String[] pathStr,Map<String,String> body ){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
      header.put("tagId", UUID.randomUUID().toString().replace("-", ""));
      String result = ArtemisHttpUtil.doGetArtemis(path, body, null,  "application/json", header);// post请求application/json类型参数
      saveInterfaceLog(JSONObject.toJSONString(body),result,path,pathStr[1]);
      return result;
   }
   public static String startDoPostStringArtemis(String[] pathStr,String body ){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
@@ -385,7 +414,38 @@
      String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post请求application/json类型参数
      saveInterfaceLog(body,result,path,pathStr[1]);
      return result;
   }
   public static String startDoPostStringArtemisAdmin(String[] pathStr,String body){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
      header.put("userId", "admin");
      String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post请求application/json类型参数
      saveInterfaceLog(body,result,path,pathStr[1]);
      return result;
   }
   public static String startDoGetStringArtemis(String[] pathStr,Map<String,String> body ){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
      header.put("tagId", UUID.randomUUID().toString().replace("-", ""));
      String result = ArtemisHttpUtil.doGetArtemis(path, body, null, null,  header);
      saveInterfaceLog(JSONObject.toJSONString(body),result,path,pathStr[1]);
      return result;
   }
   public static String startDoGetStringArtemis(String[] pathStr,Map<String,String> querys ,Map<String, String> header ){
      Map<String, String> path = getPath(pathStr[0]);
      String result = ArtemisHttpUtil.doGetArtemis(path, querys, null, null,  header);
      saveInterfaceLog(JSONObject.toJSONString(querys),result,path,pathStr[1]);
      return result;
   }
   public static String startDoGetStringArtemisJson(String[] pathStr,Map<String,String> body ){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
      String result = ArtemisHttpUtil.doGetArtemis(path, body, null, "application/json",  header);
      saveInterfaceLog(JSONObject.toJSONString(body),result,path,pathStr[1]);
      return result;
   }
   public static String startDoPostStringArtemis(String[] pathStr,String param,String body ){
      Map<String, String> path = getPath(pathStr[0]+StringUtils.defaultString(param,""));
@@ -394,15 +454,15 @@
      String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post请求application/json类型参数
      saveInterfaceLog(body,result,path,pathStr[1]);
      return result;
   }
   public static String startDoPostStringArtemis(String[] pathStr,Map<String, String> querys,Map<String, String> header,String body){
      Map<String, String> path = getPath(pathStr[0]);
      header.put("tagId", UUID.randomUUID().toString().replace("-", ""));
      String result = ArtemisHttpUtil.doPostStringArtemis(path, body, querys, null, "application/json", header);// post请求application/json类型参数
      saveInterfaceLog(body,result,path,pathStr[1]);
      return result;
   }
   /**
    *   签离访客预约
@@ -411,6 +471,22 @@
    */
   public static String visitOut(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.visitOut,body);
   }
   /**
    *   iccm签离访客预约
    * @param body
    * @return
    */
   public static String iccmSignoff(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.iccmSignoff,body);
   }
   /**
    *   iccm取消访客预约
    * @param body
    * @return
    */
   public static String iccmCancelAppointment(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.iccmCancelAppointment,body);
   }
   /**
    *   访客权限组
@@ -566,10 +642,13 @@
    *   根据微信公众号信息获取AccessToken
    * @return
    */
   public static String wxAccessToken(String configId,String tagId) {
      String[] wxAccessToken= HKConstants.InterfacePath.wxAccessToken;
      wxAccessToken[0] = HKConstants.InterfacePath.wxAccessToken+"?tagId="+tagId+"&configId"+configId;
      return startDoPostStringArtemis(wxAccessToken,"");
   public static String wxAccessToken(HashMap<String,String> params ) {
//      String[] wxAccessToken= new String[2];
//      String url = HKConstants.InterfacePath.wxAccessToken[0]+"?tagId="+tagId+"&configId="+configId;
//      String t = HKConstants.InterfacePath.wxAccessToken[1];
//      wxAccessToken[0] = url;
//      wxAccessToken[1] = t;
      return startDoGetStringArtemisJson(HKConstants.InterfacePath.wxAccessToken,params);
   }
   /**
    *   根据配置微信公众号编号查询微信公众号信息
@@ -735,6 +814,184 @@
      return startDoPostStringArtemis(HKConstants.InterfacePath.platformsList,body);
   }
   /**
    * 获取消防传感器列表
    * @param body
    * @return
    */
   public static String pageFireChannel(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.pageFireChannel,body);
   }
   /**
    * 查询消防传感器部件状态v2
    * @param body
    * @return
    */
   public static String pageSensorStatus(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.pageSensorStatus,body);
   }
   /**
    * 安防看板-今日告警事件-根据eventType字段3
    * @param body
    * @return
    */
   public static String ruleEventSearch(String body) {
      Map<String,String> header = new HashMap<>();
      header.put("User-Id","admin");
      return startDoPostStringArtemis(HKConstants.InterfacePath.ruleEventSearch,null,header,body);
   }
   /**
    * 安防看板-园区安防设备-各类型设备状态数据列表
    * @param body
    * @return
    */
   public static String getSecureDevStatusList(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.getSecureDevStatusList,body);
   }
   /**
    * 能耗看板-6按月查询近12个月的用电总量数据
    * @param body
    * @return
    */
   public static String energyTrend(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.energyTrend,body);
   }
   /**
    * 消防维保统计
    * @param body
    * @return
    */
   public static String fireStatistic(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.fireStatistic,body);
   }
   /**
    * 消防维保每月新增统计
    * @param body
    * @return
    */
   public static String fireStatisticMonth(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.fireStatisticMonth,body);
   }
   /**
    * 消防看板-消防设备在离线1
    * @param body
    * @return
    */
   public static String getFireDevStatusTotal(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.getFireDevStatusTotal,body);
   }
   /**
    * 消防看板-各类型设备在线率2
    * @param body
    * @return
    */
   public static String getFireDevStatusList(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.getFireDevStatusList,body);
   }
   /**
    * 分页查询设备的以及下属传感器数据的状态统计
    * @param body
    * @return
    */
   public static String findDeviceStatistics(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.findDeviceStatistics,body);
   }
   /**
    *消防看板-4报警信息统计
    * @param body
    * @return
    */
   public static String findAlarmBaseDataStatistic(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.findAlarmBaseDataStatistic,body);
   }
   /**
    *安防看板-- b
    * @param body
    * @return
    */
   public static String findHomeAlarmInfoPage(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.findHomeAlarmInfoPage,body);
   }
   /**
    *保存用户及openId绑定信息微信公众号
    * @param body
    * @return
    */
   public static String userOpenidSave(String body) {
      Map<String,String> header = new HashMap<>();
      header.put("userId","admin");
      return startDoPostStringArtemis(HKConstants.InterfacePath.userOpenidSave,null,header,body);
   }
   /**
    *通过openId或userName等删除绑定信息
    * @param param
    * @return
    */
   public static String userOpenidDel(Map<String,String>  param) {
      Map<String,String> header = new HashMap<>();
      header.put("userId","admin");
      return startDoGetStringArtemis(HKConstants.InterfacePath.userOpenidDel,param,header);
   }
   /**
    *分页查询设备监测历史数据
    * @param body
    * @return
    */
   public static String minitorDataSearch(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.minitorDataSearchV1,body);
   }
   /**
    * 统计园区总体的安防设备数量,在线数、在线率、离线数、离线率
    * @param body
    * @return
    */
   public static String getSecureDevStatusTotal(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.getSecureDevStatusTotal,body);
   }
   /**
    * 统安防看板--园区实时车数量4
    * @return
    */
   public static String getParkingStatistics() {
      return startDoGetStringArtemis(HKConstants.InterfacePath.getParkingStatistics,null);
   }
   /**
    * 能耗看板-1.获取本月用能总量-自然月
    * @return
    */
   public static String getCurrentMonthDataByMeterType(Map<String,String>   powerType) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.getCurrentMonthDataByMeterType,powerType);
   }
   /**
    * 能耗看板-2.获取区域用能前N位
    * @return
    */
   public static String regionTopPower(Map<String,String>   params) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.regionTopPower,params);
   }
   /**
    * 能耗看板-3.获取各区域用能及总能耗
    * @return
    */
   public static String regionEnergyList(Map<String,String>   params) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.regionEnergyList,params);
   }
   /**
    * 能耗看板-4.获取上月用能费用,一天刷新,凌晨某个点刷
    * @return
    */
   public static String lastMonthFeeByMeterType(Map<String,String>   params) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.lastMonthFeeByMeterType,params);
   }
   /**
    * 能耗看板-5.园区实时负荷曲线
    * @return
    */
   public static String energyTodayLoadData( ) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.energyTodayLoadData,null);
   }
   /**
    * 获取月台状态
    * @return
    */
@@ -745,6 +1002,50 @@
         return startDoPostStringArtemis(HKConstants.InterfacePath.platformStatus,null);
      }
   }
   /**
    * 获取菜单
    * @param body
    * @return
    */
   public static String getHkMenu(Map<String,String> body) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.getMenus,body);
   }
   /**
    * 分页获取区域列表
    * @param body
    * @return
    */
   public static String pageRegions(Map<String,String> header,String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.pageRegions,null,header,body);
   }
   /**
    * 分页获取监控点资源
    * @param body
    * @return
    */
   public static String pageCameras(Map<String,String> header,String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.pageCameras,null,header,body);
   }
   /**
    * 获取监控点预览取流URL
    * @param body
    * @return
    */
   public static String cameraPreviewURLs(Map<String,String> header,String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.cameraPreviewURLs,null,header,body);
   }
   /**
    * 发送短信验证码
    * @param body
    * @return
    */
   public static String sendSms(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.sendSms,body);
   }
   /**
    * 获取月台组件配置的LED设备清单
    * @param body
@@ -796,9 +1097,9 @@
      return startDoPostStringArtemis(HKConstants.InterfacePath.applyST,body);
   }
   public static String getMenuUrl(String menuId, String token) {
   public static String getMenuUrl(String componentId,String menuId, String token) {
      String url = HKConstants.InterfacePath.goMenuUrl[0];
      url = url.replace("${menuId}", menuId).replace("${token}",token);
      url = url.replace("${componentId}",componentId).replace("${menuId}", menuId).replace("${token}",token);
      return  url;
   }
}