From 9bd9584c376f225280b93836df51c0e106e5ea05 Mon Sep 17 00:00:00 2001 From: zhanghua <314079846@qq.com> Date: 星期一, 03 四月 2023 21:51:15 +0800 Subject: [PATCH] 预警研判 --- ycl-platform/src/main/java/com/ycl/util/VideoUtil.java | 130 +++++++++++++++++++++++++------------------ 1 files changed, 76 insertions(+), 54 deletions(-) diff --git a/ycl-platform/src/main/java/com/ycl/util/VideoUtil.java b/ycl-platform/src/main/java/com/ycl/util/VideoUtil.java index 00fdbb1..103223b 100644 --- a/ycl-platform/src/main/java/com/ycl/util/VideoUtil.java +++ b/ycl-platform/src/main/java/com/ycl/util/VideoUtil.java @@ -22,78 +22,100 @@ public class VideoUtil { @Value("${videoPoint.url}") - private String url; + private String url; @Value("${videoPoint.userName}") - private String userName; + private String userName; @Value("${videoPoint.passWord}") - private String passWord; + private String passWord; @Value("${videoPoint.ip}") - private String ip; + private String ip; + /* + * @Description subType:绫诲瀷int锛岄�夊~銆傜爜娴佺被鍨嬶紝0:涓荤爜娴併��1:杈呮祦1銆�2:杈呮祦2銆傞粯璁や负0涓荤爜娴併�俿cheme:绫诲瀷string锛岄�夊~銆傚崗璁被鍨嬶紝鏀寔RTSP銆丗LV_HTTP銆丠LS涓夌锛岄粯璁TSP銆� + * @Param [code, scheme, subType] + * @return java.lang.String + **/ @SneakyThrows - public String getVideo(String code, String scheme,Integer subType) { - String clientType = "winpc"; - String reqUrl = "/videoService/accounts/authorize"; - String deviceUrl = "/videoService/devicesManager/devices"; - String monitorUrl = "/videoService/realmonitor/uri?subType=" + subType + "&scheme=" + scheme + "&channelId="; + public String getVideo(String code, String scheme, Integer subType) { + // System.out.println("寮�濮嬭棰戣姹傦細" + code); + try { - RestTemplate restTemplate = new RestTemplate(); - restTemplate.setErrorHandler(new DefaultResponseErrorHandler() { - @Override - public boolean hasError(HttpStatus status) { - return super.hasError(status); + String clientType = "winpc"; + String reqUrl = "/videoService/accounts/authorize"; + String deviceUrl = "/videoService/devicesManager/devices"; +// String monitorUrl = "/videoService/realmonitor/uri?subType=" + subType + "&scheme=" + scheme + "&channelId="; + + String monitorUrl = "/videoService/realmonitor/uri?trackId=&encryptedInfo=&userId=&urlType=1&keyIndex=®ionId=&packtype=Private&planId=&subType=" + subType + "&isroute=false&streamType=&locationEnable=false&domainId=&duration=600&scheme=RTSP&dataType=2&extend=&channelId="; + if (!"RTSP".equals(scheme)) { + monitorUrl = "/videoService/realmonitor/uri?subType=" + subType + "&scheme=" + scheme + "&channelId="; } + RestTemplate restTemplate = new RestTemplate(); + restTemplate.setErrorHandler(new DefaultResponseErrorHandler() { + @Override + public boolean hasError(HttpStatus status) { + return super.hasError(status); + } - @Override - public void handleError(URI url, HttpMethod method, ClientHttpResponse response) { + @Override + public void handleError(URI url, HttpMethod method, ClientHttpResponse response) { - } - }); - SimpleClientHttpRequestFactory simpleClientHttpRequestFactory = new SimpleClientHttpRequestFactory(); - simpleClientHttpRequestFactory.setOutputStreaming(false); - restTemplate.setRequestFactory(simpleClientHttpRequestFactory); + } + }); + SimpleClientHttpRequestFactory simpleClientHttpRequestFactory = new SimpleClientHttpRequestFactory(); + simpleClientHttpRequestFactory.setOutputStreaming(false); + restTemplate.setRequestFactory(simpleClientHttpRequestFactory); - //璇锋眰澶� - HttpHeaders httpHeaders = new HttpHeaders(); - httpHeaders.setContentType(MediaType.APPLICATION_JSON); + //璇锋眰澶� + HttpHeaders httpHeaders = new HttpHeaders(); + httpHeaders.setContentType(MediaType.APPLICATION_JSON); - //绗竴娆℃潈闄愯姹備綋 - FirstReq firstReq = new FirstReq(); - firstReq.setIpAddress(ip); - firstReq.setUserName(userName); - firstReq.setClientType(clientType); - ObjectMapper objectMapper = new ObjectMapper(); + //绗竴娆℃潈闄愯姹備綋 + FirstReq firstReq = new FirstReq(); + firstReq.setIpAddress(ip); + firstReq.setUserName(userName); + firstReq.setClientType(clientType); + ObjectMapper objectMapper = new ObjectMapper(); - HttpEntity<String> firstEntity = new HttpEntity<>(objectMapper.writeValueAsString(firstReq), httpHeaders); - ResponseEntity<String> responseEntity = restTemplate.postForEntity(url + reqUrl, firstEntity, String.class); + HttpEntity<String> firstEntity = new HttpEntity<>(objectMapper.writeValueAsString(firstReq), httpHeaders); + ResponseEntity<String> responseEntity = restTemplate.postForEntity(url + reqUrl, firstEntity, String.class); - FirstRes firstRes = objectMapper.readValue(responseEntity.getBody(), FirstRes.class); + FirstRes firstRes = objectMapper.readValue(responseEntity.getBody(), FirstRes.class); - String signature = MD5Util.md5Encrypt(passWord); - signature = MD5Util.md5Encrypt(userName + signature); - signature = MD5Util.md5Encrypt(signature); - signature = MD5Util.md5Encrypt(userName + ":" + firstRes.getRealm() + ":" + signature); - signature = MD5Util.md5Encrypt(signature + ":" + firstRes.getRandomKey()); + String signature = MD5Util.md5Encrypt(passWord); + signature = MD5Util.md5Encrypt(userName + signature); + signature = MD5Util.md5Encrypt(signature); + signature = MD5Util.md5Encrypt(userName + ":" + firstRes.getRealm() + ":" + signature); + signature = MD5Util.md5Encrypt(signature + ":" + firstRes.getRandomKey()); - SecondReq secondReq = new SecondReq(); - secondReq.setIpAddress(ip); - secondReq.setEncryptType(firstRes.getEncryptType()); - secondReq.setSignature(signature); - secondReq.setRandomKey(firstRes.getRandomKey()); - secondReq.setClientType(clientType); - secondReq.setUserName(userName); + SecondReq secondReq = new SecondReq(); + secondReq.setIpAddress(ip); + secondReq.setEncryptType(firstRes.getEncryptType()); + secondReq.setSignature(signature); + secondReq.setRandomKey(firstRes.getRandomKey()); + secondReq.setClientType(clientType); + secondReq.setUserName(userName); - HttpEntity<String> secondEntity = new HttpEntity<>(objectMapper.writeValueAsString(secondReq), httpHeaders); - ResponseEntity<String> secondResEntity = restTemplate.postForEntity(url + reqUrl, secondEntity, String.class); - HttpHeaders deviceHeaders = new HttpHeaders(); - deviceHeaders.add("X-Subject-Token", objectMapper.readTree(secondResEntity.getBody()).get("token").textValue()); - HttpEntity<Object> deviceEntity = new HttpEntity<>(deviceHeaders); - ResponseEntity<String> exchange = restTemplate.exchange(url + deviceUrl + "/" + code, HttpMethod.GET, deviceEntity, String.class); - String channelId = objectMapper.readTree(objectMapper.readTree(objectMapper.readTree(exchange.getBody()).get("encoderUnit").toString()).get("channels").get(0).toString()).get("channelId").textValue(); - ResponseEntity<String> monitorReq = restTemplate.exchange(url + monitorUrl + channelId, HttpMethod.GET, deviceEntity, String.class); - return objectMapper.readTree(monitorReq.getBody()).get("url").textValue(); + HttpEntity<String> secondEntity = new HttpEntity<>(objectMapper.writeValueAsString(secondReq), httpHeaders); + ResponseEntity<String> secondResEntity = restTemplate.postForEntity(url + reqUrl, secondEntity, String.class); + HttpHeaders deviceHeaders = new HttpHeaders(); + deviceHeaders.add("X-Subject-Token", objectMapper.readTree(secondResEntity.getBody()).get("token").textValue()); + HttpEntity<Object> deviceEntity = new HttpEntity<>(deviceHeaders); + // System.out.println("瑙嗛璁惧璇锋眰鍦板潃锛�" + url + deviceUrl + "/" + code); + + ResponseEntity<String> exchange = restTemplate.exchange(url + deviceUrl + "/" + code, HttpMethod.GET, deviceEntity, String.class); + // System.out.println("寮�濮嬭棰戣韩浠借姹傜粨鏋滐細" + exchange.getBody()); + String channelId = objectMapper.readTree(objectMapper.readTree(objectMapper.readTree(exchange.getBody()).get("encoderUnit").toString()).get("channels").get(0).toString()).get("channelId").textValue(); + // System.out.println("瑙嗛璇锋眰鍦板潃锛�" + url + monitorUrl + channelId); + ResponseEntity<String> monitorReq = restTemplate.exchange(url + monitorUrl + channelId, HttpMethod.GET, deviceEntity, String.class); + // System.out.println("瑙嗛璇锋眰杩斿洖鍙傛暟锛�" + monitorReq.getBody()); + return objectMapper.readTree(monitorReq.getBody()).get("url").textValue(); + + } catch (Exception ex) { + System.out.println("鑾峰彇瑙嗛寮傚父锛�" + ex); + return "鑾峰彇鍦板潃澶辫触锛岃妫�鏌ode鍊�"; + } } } -- Gitblit v1.8.0