jiangping
2024-10-12 829f863fe0c6be33067d9fd4115660472bf20852
server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
@@ -1,10 +1,8 @@
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.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 +11,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
@@ -79,9 +73,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 +240,7 @@
         InputStream in = entity.getContent();
         return  in;
      }else{
         log.error("人脸下载出错");
         throw  new Exception("人脸下载出错");
      }
   }
@@ -302,6 +297,14 @@
      }else{
         throw  new Exception("查询车辆抓拍图片下载出错");
      }
   }
   /**
    * 分页获取待办列表
    * @param body
    * @return
    */
   public static String getTodoListPage(Map<String, String> body)  throws  Exception{
      return startDoGetStringArtemis(HKConstants.InterfacePath.getTodoListPage,body);
   }
   /**
    *   获取门禁点列表
@@ -369,6 +372,7 @@
      return  startDoPostStringArtemis(HKConstants.InterfacePath.visitCancel,body);
   }
   public static String startDoPostStringArtemis(String[] pathStr,String body ){
      Map<String, String> path = getPath(pathStr[0]);
      Map<String, String> header = new HashMap<>();
@@ -376,7 +380,14 @@
      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 startDoPostStringArtemis(String[] pathStr,String param,String body ){
      Map<String, String> path = getPath(pathStr[0]+StringUtils.defaultString(param,""));
@@ -529,6 +540,14 @@
   }
   /**
    *   获取全量组织信息
    * @param body
    * @return
    */
   public static String orgAllList(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.orgAllList,body);
   }
   /**
    *   获取访客预约记录列表
    * @param body
    * @return
@@ -546,12 +565,71 @@
      return startDoPostStringArtemis(HKConstants.InterfacePath.iccmAppointmentRecords,body);
   }
   /**
    *   获取全量组织列表
    *   根据微信公众号信息获取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,"");
   }
   /**
    *   根据配置微信公众号编号查询微信公众号信息
    * @param body
    * @return
    */
   public static String orgAllList(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.orgAllList,body);
   public static String getWxConfig(Map<String,String>  body) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.getWxConfig,body);
   }
   /**
    *   根据配置微信公众号编号查询微信公众号信息
    * @param body
    * @return
    */
   public static String nhEventPageList(Map<String,String> body) {
      return startDoGetStringArtemis(HKConstants.InterfacePath.nhEventPageList,body);
   }
   /**
    *   查询消防设备部件状态
    * @param body
    * @return
    */
   public static String fireDeviceStatusSearch(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceStatusSearch,body);
   }
   /**
    * 分页查询消防传感器部件状态
    * @param body
    * @return
    */
   public static String sensorStatusSearch(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.sensorStatusSearch,body);
   }
   /**
    * 分页查询设备下的所有报警记录
    * @param body
    * @return
    */
   public static String findDeviceAlarmPage(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.findDeviceAlarmPage,body);
   }
   /**
    *   询消防设备列表
    * @param body
    * @return
    */
   public static String fireChannelSearch(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.fireChannelSearch,body);
   }
   /**
    *   询消防设备列表
    * @param body
    * @return
    */
   public static String fireDeviceSearch(String body) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceSearch,body);
   }
   /**
    *   获取全量用户列表
@@ -720,4 +798,9 @@
      return startDoPostStringArtemis(HKConstants.InterfacePath.applyST,body);
   }
   public static String getMenuUrl(String menuId, String token) {
      String url = HKConstants.InterfacePath.goMenuUrl[0];
      url = url.replace("${menuId}", menuId).replace("${token}",token);
      return  url;
   }
}