From a94aacd36460d76297878c304f4837813191232c Mon Sep 17 00:00:00 2001 From: rk <94314517@qq.com> Date: 星期一, 29 九月 2025 18:04:47 +0800 Subject: [PATCH] 钉钉授权 与 通知开发 --- server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java | 418 +++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 373 insertions(+), 45 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java index b9e3b0d..d305617 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java @@ -1,10 +1,14 @@ package com.doumee.core.haikang.model; import com.alibaba.fastjson.JSONObject; -import com.doumee.config.SpringContextUtil; +import com.doumee.core.haikang.model.param.BaseResponse; import com.doumee.core.haikang.model.param.request.CarPictureRequest; +import com.doumee.core.haikang.model.param.request.FacePictureCheckRequest; +import com.doumee.core.haikang.model.param.request.ParkReservationAddRequest; +import com.doumee.core.haikang.model.param.request.VisitAppointmentCancelRequest; import com.doumee.core.haikang.service.HKService; import com.doumee.core.utils.Constants; +import com.doumee.core.utils.DateUtil; import com.doumee.dao.business.model.InterfaceLog; import com.doumee.service.business.InterfaceLogService; import com.hikvision.artemis.sdk.ArtemisHttpUtil; @@ -13,18 +17,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 +34,18 @@ 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(); + + VisitAppointmentCancelRequest request = new VisitAppointmentCancelRequest(); + request.setAppointRecordIds(new String[]{"鐨朅90LL0"}); + String response = iccmCancelAppointment(JSONObject.toJSONString(request)); + System.out.println(response); + + /* 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 +64,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 +90,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);// 鏍规嵁鐜板満鐜閮ㄧ讲纭鏄痟ttp杩樻槸https - } + { + put(HKConstants.https, getCamsApi);// 鏍规嵁鐜板満鐜閮ㄧ讲纭鏄痟ttp杩樻槸https + } }; return path; } @@ -246,6 +257,7 @@ InputStream in = entity.getContent(); return in; }else{ + log.error("浜鸿劯涓嬭浇鍑洪敊"); throw new Exception("浜鸿劯涓嬭浇鍑洪敊"); } } @@ -303,6 +315,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 +417,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 +425,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 +465,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 +482,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 +653,13 @@ * 鏍规嵁寰俊鍏紬鍙蜂俊鎭幏鍙朅ccessToken * @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); } /** * 鏍规嵁閰嶇疆寰俊鍏紬鍙风紪鍙锋煡璇㈠井淇″叕浼楀彿淇℃伅 @@ -593,24 +683,32 @@ * @param body * @return */ - public static String fireDeviceStatusSearch(Map<String,String> body) { - return startDoGetStringArtemis(HKConstants.InterfacePath.fireDeviceStatusSearch,body); + public static String fireDeviceStatusSearch(String body) { + return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceStatusSearch,body); } /** - * 鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬� + * 鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬� * @param body * @return */ - public static String sensorStatusSearch(Map<String,String> body) { - return startDoGetStringArtemis(HKConstants.InterfacePath.sensorStatusSearch,body); + 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(Map<String,String> body) { - return startDoGetStringArtemis(HKConstants.InterfacePath.fireChannelSearch,body); + public static String fireChannelSearch(String body) { + return startDoPostStringArtemis(HKConstants.InterfacePath.fireChannelSearch,body); } /** @@ -618,8 +716,8 @@ * @param body * @return */ - public static String fireDeviceSearch(Map<String,String> body) { - return startDoGetStringArtemis(HKConstants.InterfacePath.fireDeviceSearch,body); + public static String fireDeviceSearch(String body) { + return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceSearch,body); } /** * 鑾峰彇鍏ㄩ噺鐢ㄦ埛鍒楄〃 @@ -727,6 +825,192 @@ return startDoPostStringArtemis(HKConstants.InterfacePath.platformsList,body); } /** + * 鑾峰彇娑堥槻浼犳劅鍣ㄥ垪琛� + * @param body + * @return + */ + public static String pageFireChannel(String body) { + return startDoPostStringArtemis(HKConstants.InterfacePath.pageFireChannel,body); + } + /** + * 鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬乿2 + * @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); + } + /** + * 銆愭捣搴锋秷闃茬湅鏉裤�戞牴鎹潯浠舵煡璇㈢洰褰曚笅鏈夋潈闄愮殑璧勬簮鍒楄〃 + * @param body + * @return + */ + public static String resourcesByParams(String body) { + return startDoPostStringArtemis(HKConstants.InterfacePath.resourcesByParams,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); + } + /** + *淇濆瓨鐢ㄦ埛鍙妎penId缁戝畾淇℃伅寰俊鍏紬鍙� + * @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鎴杣serName绛夊垹闄ょ粦瀹氫俊鎭� + * @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.鑾峰彇鍖哄煙鐢ㄨ兘鍓峃浣� + * @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 */ @@ -737,6 +1021,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); + } + /** + * 鑾峰彇鐩戞帶鐐归瑙堝彇娴乁RL + * @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); + } + /** * 鑾峰彇鏈堝彴缁勪欢閰嶇疆鐨凩ED璁惧娓呭崟 * @param body @@ -788,9 +1116,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; } } -- Gitblit v1.9.3