jiangping
2024-12-24 a825583ed6c4df0998248be80dccf1e9fa35bc56
server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
@@ -2,6 +2,7 @@
import com.alibaba.fastjson.JSONObject;
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.dao.business.model.InterfaceLog;
import com.doumee.service.business.InterfaceLogService;
@@ -28,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);
@@ -51,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;
@@ -234,26 +240,15 @@
      Map<String, String> path = getPath(HKConstants.InterfacePath.facePicture[0]);
      //参数根据接口实际情况设置
      log.error("=========================ArtemisConfig.host***********************************"+ ArtemisConfig.host);
      log.error("=========================ArtemisConfig.key********************************"+ArtemisConfig.appKey);
      try {
         log.error("-------------------------ArtemisConfig.host***********************************"+ ArtemisConfig.host);
         log.error("-------------------------ArtemisConfig.key********************************"+ArtemisConfig.appKey);
         HttpResponse resp = ArtemisHttpUtil.doPostStringImgArtemis( path, body, null, null,"application/json",null);
         if (200==resp.getStatusLine().getStatusCode()) {
            HttpEntity entity = resp.getEntity();
            InputStream in = entity.getContent();
            return  in;
         }else{
            log.error("人脸下载出错");
            throw  new Exception("人脸下载出错");
         }
      }catch (Exception e){
         e.printStackTrace();
      HttpResponse resp = ArtemisHttpUtil.doPostStringImgArtemis( path, body, null, null,"application/json",null);
      if (200==resp.getStatusLine().getStatusCode()) {
         HttpEntity entity = resp.getEntity();
         InputStream in = entity.getContent();
         return  in;
      }else{
         log.error("人脸下载出错");
         throw  new Exception("人脸下载出错");
      }
      log.error("+++++++++++++++++++++++++ArtemisConfig.host***********************************"+ ArtemisConfig.host);
      log.error("+++++++++++++++++++++++++ArtemisConfig.key********************************"+ArtemisConfig.appKey);
      return  null;
   }
   /**
    * 获取访客记录中的图片
@@ -309,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
@@ -375,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<>();
@@ -391,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,""));
@@ -400,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;
   }
   /**
    *   签离访客预约
@@ -572,10 +626,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);
   }
   /**
    *   根据配置微信公众号编号查询微信公众号信息
@@ -741,6 +798,173 @@
      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) {
      return startDoPostStringArtemis(HKConstants.InterfacePath.ruleEventSearch,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);
   }
   /**
    *消防看板-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
    */
@@ -751,6 +975,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
@@ -802,9 +1070,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;
   }
}