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=&regionId=&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