From 2132ba97b4ce7d2dd0d90a510090122a5cc52ca6 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期五, 05 一月 2024 08:59:13 +0800 Subject: [PATCH] 海康接口对接开发 --- server/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java | 251 +++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 235 insertions(+), 16 deletions(-) diff --git a/server/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java b/server/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java index 49aa419..3a9f27e 100644 --- a/server/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java +++ b/server/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java @@ -1,13 +1,26 @@ package com.doumee.core.haikang.model; import com.alibaba.fastjson.JSONObject; +import com.doumee.config.SpringContextUtil; +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; +import com.hikvision.artemis.sdk.config.ArtemisConfig; import lombok.extern.slf4j.Slf4j; 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.BufferedReader; import java.io.IOException; import java.io.InputStream; +import java.io.InputStreamReader; +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; @@ -20,9 +33,40 @@ // private static final Logger logger = LoggerFactory.getLogger(HKUtil.class); - public static void main(String[] args) throws ParseException { + public static void main(String[] args) throws Exception { +// Proxy proxy = new Proxy(Proxy.Type.DIRECT, new InetSocketAddress("127.0.0.1",Integer.valueOf("1080"))); + URL realUrl = new URL("https://10.50.60.253/artemis/api/eventService/v1/eventSubscriptionByEventTypes"); + HttpURLConnection con = (HttpURLConnection) realUrl.openConnection(); + con.setRequestMethod("GET"); +// con.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:57.0) ;Gecko/20100101 Firefox/57.0"); + BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream())); + String inputLine; + StringBuffer content = new StringBuffer(); + while ((inputLine = in.readLine()) != null) { + content.append(inputLine); + } + in.close(); + con.disconnect(); + + System.out.println(content.toString()); } + public static InterfaceLogService interfaceLogService = null; + private static void saveInterfaceLog(String s, String result,Map<String, String> path) { +// InterfaceLogService bean = SpringContextUtil.getBean(InterfaceLogService.class); + if(interfaceLogService !=null){ + InterfaceLog hkMonitoryLogDO=new InterfaceLog(); + hkMonitoryLogDO.setType(0); + hkMonitoryLogDO.setCreateDate(new Date()); + hkMonitoryLogDO.setIsdeleted(0); + hkMonitoryLogDO.setRequest(s); + hkMonitoryLogDO.setRepose(result); + hkMonitoryLogDO.setName(path.get(HKConstants.https)); + hkMonitoryLogDO.setUrl(HKConstants.https + ArtemisConfig.host+path.get(HKConstants.https)); + interfaceLogService.create(hkMonitoryLogDO); + } + } + private static Map<String, String> getPath(String str) { final String getCamsApi = HKConstants.ARTEMIS_PATH + str; Map<String, String> path = new HashMap<String, String>(2) { @@ -40,8 +84,10 @@ public static String getRootOrg() { Map<String, String> path = getPath(HKConstants.InterfacePath.rootOrg); String result = ArtemisHttpUtil.doPostStringArtemis(path, "", null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog("",result,path); return result; } + /** * 鏇存柊缁勭粐淇℃伅 @@ -51,6 +97,7 @@ public static String editOrg(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.editOrg); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -62,6 +109,7 @@ public static String addBatchOrg(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.addBatchOrg); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -72,6 +120,7 @@ public static String delOrg(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.delBatchOrg); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -83,6 +132,7 @@ public static String addUser(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.addUser); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -95,6 +145,7 @@ public static String addBatchUser(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.addBatchUser); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -106,6 +157,7 @@ public static String delBatchUser(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.delBatchUser); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -117,6 +169,7 @@ public static String editUser(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.editUser); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -127,6 +180,7 @@ public static String addFace(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.addFace); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -137,6 +191,7 @@ public static String editFace(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.editFace); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -147,6 +202,7 @@ public static String delFace(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.delFace); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -157,6 +213,7 @@ public static String parkList(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.getParkList); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -167,6 +224,7 @@ public static String entranceList(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.getEntranceList); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -177,6 +235,7 @@ public static String parkAddition(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.parkAddition); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -187,6 +246,7 @@ public static String parkDeletion(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.parkDeletion); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -197,6 +257,7 @@ public static String carChargeAddtion(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.carChargeAddtion); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -207,6 +268,7 @@ public static String carChargeDeletion(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.carChargeDeletion); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -230,6 +292,71 @@ } } /** + * 鑾峰彇璁垮璁板綍涓殑鍥剧墖 + * @param body + * @return + */ + public static InputStream getVisitPicture(String body) throws Exception{ + + Map<String, String> path = getPath(HKConstants.InterfacePath.visitPicture); + //鍙傛暟鏍规嵁鎺ュ彛瀹為檯鎯呭喌璁剧疆 + 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{ + throw new Exception("鑾峰彇璁垮璁板綍涓殑鍥剧墖涓嬭浇鍑洪敊"); + } + } + /** + * 鑾峰彇闂ㄧ浜嬩欢鐨勫浘鐗� + * @param body + * @return + */ + public static InputStream getDevicePicture(String body) throws Exception{ + + Map<String, String> path = getPath(HKConstants.InterfacePath.devicePicture); + //鍙傛暟鏍规嵁鎺ュ彛瀹為檯鎯呭喌璁剧疆 + 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{ + throw new Exception("鑾峰彇闂ㄧ浜嬩欢鐨勫浘鐗囦笅杞藉嚭閿�"); + } + } + /** + * 鏌ヨ杞﹁締鎶撴媿鍥剧墖 + * @param body + * @return + */ + public static InputStream getCarPicture(String body) throws Exception{ + + Map<String, String> path = getPath(HKConstants.InterfacePath.carPicture); + //鍙傛暟鏍规嵁鎺ュ彛瀹為檯鎯呭喌璁剧疆 + 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{ + throw new Exception("鏌ヨ杞﹁締鎶撴媿鍥剧墖涓嬭浇鍑洪敊"); + } + } + /** + * 鑾峰彇闂ㄧ鐐瑰垪琛� + * @param body + * @return + */ + public static String doorSearch(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.doorSearch); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** * 鑾峰彇闂ㄧ璁惧鍒楄〃 * @param body * @return @@ -237,6 +364,7 @@ public static String acsDeviceList(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.acsDeviceList); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -247,6 +375,7 @@ public static String acsDeviceTimeRangeList(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.acsDeviceList); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -257,6 +386,7 @@ public static String visitAppiontment(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.visitAppiontment); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -267,6 +397,7 @@ public static String visitAppiontmentMDJ(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.visitAppiontmentMDJ); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } @@ -278,6 +409,18 @@ public static String visitCancel(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.visitCancel); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 绛剧璁垮棰勭害 + * @param body + * @return + */ + public static String visitOut(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.visitOut); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } /** @@ -288,23 +431,99 @@ public static String privilegeGroup(String body) { Map<String, String> path = getPath(HKConstants.InterfacePath.privilegeGroup); String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); return result; } - - - /** - * 浼犲叆Data绫诲瀷鏃ユ湡锛岃繑鍥炲瓧绗︿覆绫诲瀷鏃堕棿锛圛SO8601鏍囧噯鏃堕棿锛� - * @param date - * @return - */ - public static String getISO8601Timestamp(Date date){ - TimeZone tz = TimeZone.getTimeZone("Asia/Shanghai"); - //TimeZone tz = TimeZone.getTimeZone("GMT-01"); - DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"); - df.setTimeZone(tz); - String nowAsISO = df.format(date); - return nowAsISO; - } + * 浜嬩欢璁㈤槄 + * @param body + * @return + */ + public static String eventSub(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.eventSub); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 鍙栨秷浜嬩欢璁㈤槄 + * @param body + * @return + */ + public static String cancelEventSub(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.cancelEventSub); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 鍒涘缓涓�鍗¢�氭潈闄愪笅杞戒换鍔� + * @param body + * @return + */ + public static String taskAddition(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.taskAddition); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 鏌ヨ涓�鍗¢�氭潈闄愭煡璇㈣澶囬�氶亾鐨勪汉鍛樻潈闄愪笅杞借鎯呮�绘暟v2 + * @param body + * @return + */ + public static String taskProgress(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.taskProgress); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 鏌ヨ涓�鍗¢�氭潈闄愪笅杞戒换鍔¤繘搴� + * @param body + * @return + */ + public static String taskProgressNum(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.taskProgressNum); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 涓�鍗¢�氭潈闄愪笅杞戒换鍔′腑娣诲姞鏁版嵁_鏍规嵁浜哄憳涓庤澶囬�氶亾鎸囧畾涓嬭浇 + * @param body + * @return + */ + public static String taskDataAddition(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.taskDataAddition); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 涓�鍗¢�氬紑濮嬩笅杞戒换鍔� + * @param body + * @return + */ + public static String taskStart(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.taskStart); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", null);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } + /** + * 鏌ヨ鏉冮檺鏉$洰鍒楄〃 + * @param body + * @return + */ + public static String authItemList(String body) { + Map<String, String> path = getPath(HKConstants.InterfacePath.authItemList); + Map<String, String> header = new HashMap<>(); + header.put("tagId", UUID.randomUUID().toString().replace("-", "")); +// header.put("tagId", "frs"); + String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post璇锋眰application/json绫诲瀷鍙傛暟 + saveInterfaceLog(body,result,path); + return result; + } } -- Gitblit v1.9.3