From 046b7c8c7a1307be3d0693ef66e4fbac1e8d24a9 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 21 三月 2025 15:25:49 +0800
Subject: [PATCH] 修改演示版本模型3执行bug

---
 guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/videoGateway/VideoGateway.java |  142 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 117 insertions(+), 25 deletions(-)

diff --git a/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/videoGateway/VideoGateway.java b/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/videoGateway/VideoGateway.java
index 7274d05..f2df95f 100644
--- a/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/videoGateway/VideoGateway.java
+++ b/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/videoGateway/VideoGateway.java
@@ -9,6 +9,7 @@
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.stylefeng.guns.core.util.ToolUtil;
 import com.stylefeng.guns.modular.system.util.videoGateway.model.*;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang.StringUtils;
@@ -111,7 +112,7 @@
 		log.info("【获取车辆列表】请求参数:" + JSON.toJSONString(body));
 		post.body(JSON.toJSONString(body));
 		HttpResponse execute = post.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			accountLogin = null;
 			if(num == 3){
@@ -165,7 +166,7 @@
 		log.info("【获取船舶列表】请求参数:" + JSON.toJSONString(body));
 		post.body(JSON.toJSONString(body));
 		HttpResponse execute = post.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
@@ -206,7 +207,7 @@
 		post.body("{}");
 		log.info("【2018年协议车辆在线】请求参数:" + post.getUrl());
 		HttpResponse execute = post.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
@@ -246,7 +247,7 @@
 		get.header("token", accountLogin.getToken());
 		log.info("【2023年协议车辆在线】请求参数:" + get.getUrl());
 		HttpResponse execute = get.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
@@ -292,11 +293,11 @@
 		log.info("【2018年协议发送拍摄指令接口】请求参数:" + JSON.toJSONString(body));
 		post.body(JSON.toJSONString(body));
 		HttpResponse execute = post.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
-				return null;
+				throw new RuntimeException("token失效,请联系管理员");
 			}
 			num++;
 			accountLogin = null;
@@ -307,10 +308,24 @@
 		Integer code = result.getInteger("code");
 		if(0 != code){
 			log.error(result.getString("msg"));
-			return null;
+			throw new RuntimeException("【2018年协议发送拍摄指令接口】失败:" + execute.body());
 		}
 		//返回文件ID
-		return result.getString("data");
+		String data = result.getString("data");
+		if(ToolUtil.isEmpty(data)){
+			if(num == 12){
+				log.error(result.getString("msg"));
+				throw new RuntimeException("【2018年协议发送拍摄指令接口】12次(1分钟)失败:" + execute.body());
+			}
+			num++;
+			try {
+				Thread.sleep(5000);
+			} catch (InterruptedException e) {
+				throw new RuntimeException(e);
+			}
+			return cameraShot2018(terminalId, channelId, num);
+		}
+		return data;
 	}
 	
 	
@@ -331,11 +346,11 @@
 		get.header("token", accountLogin.getToken());
 		log.info("【2023年协议发送拍摄指令接口】请求参数:" + get.getUrl());
 		HttpResponse execute = get.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
-				return null;
+				throw new RuntimeException("token失效,请联系管理员");
 			}
 			num++;
 			accountLogin = null;
@@ -346,10 +361,24 @@
 		Integer code = result.getInteger("code");
 		if(0 != code){
 			log.error(result.getString("msg"));
-			return null;
+			throw new RuntimeException("【2023年协议发送拍摄指令接口】失败:" + execute.body());
 		}
 		//返回文件ID
-		return result.getString("data");
+		String data = result.getString("data");
+		if(ToolUtil.isEmpty(data)){
+			if(num == 12){
+				log.error(result.getString("msg"));
+				throw new RuntimeException("【2023年协议发送拍摄指令接口】12次(1分钟)失败:" + execute.body());
+			}
+			num++;
+			try {
+				Thread.sleep(5000);
+			} catch (InterruptedException e) {
+				throw new RuntimeException(e);
+			}
+			return cameraShot2023(vehicleId, vehicleType, terminalId, channelId, num);
+		}
+		return data;
 	}
 	
 	
@@ -368,11 +397,11 @@
 		get.header("token", accountLogin.getToken());
 		log.info("【2018年协议车辆获取拍摄图片】请求参数:" + get.getUrl());
 		HttpResponse execute = get.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
-				return null;
+				throw new RuntimeException("token失效,请联系管理员");
 			}
 			num++;
 			accountLogin = null;
@@ -383,12 +412,22 @@
 		Integer code = result.getInteger("code");
 		if(0 != code){
 			log.error(result.getString("msg"));
-			return null;
+			throw new RuntimeException("【2018年协议车辆获取拍摄图片】失败:" + execute.body());
 		}
 		//图片地址
 		String data = result.getString("data");
-		if(null == data){
-			return null;
+		if(ToolUtil.isEmpty(data)){
+			if(num == 60){
+				log.error(result.getString("msg"));
+				throw new RuntimeException("【2018年协议车辆获取拍摄图片】60次(1分钟)失败:" + execute.body());
+			}
+			num++;
+			try {
+				Thread.sleep(1000);
+			} catch (InterruptedException e) {
+				throw new RuntimeException(e);
+			}
+			return getCameraShotByFileId2018(terminalId, fileId, num);
 		}
 		data = data.replaceAll(";", "");
 		return "https://zhyn-pic.cg.gz.gov.cn" + data;
@@ -409,11 +448,11 @@
 		get.header("token", accountLogin.getToken());
 		log.info("【2023年协议车辆获取拍摄图片】请求参数:" + get.getUrl());
 		HttpResponse execute = get.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
-				return null;
+				throw new RuntimeException("token失效,请联系管理员");
 			}
 			num++;
 			accountLogin = null;
@@ -424,12 +463,22 @@
 		Integer code = result.getInteger("code");
 		if(0 != code){
 			log.error(result.getString("msg"));
-			return null;
+			throw new RuntimeException("【2023年协议车辆获取拍摄图片】失败:" + execute.body());
 		}
 		//图片地址
 		String data = result.getString("data");
-		if(null == data){
-			return null;
+		if(ToolUtil.isEmpty(data)){
+			if(num == 60){
+				log.error(result.getString("msg"));
+				throw new RuntimeException("【2023年协议车辆获取拍摄图片】60次(1分钟)失败:" + execute.body());
+			}
+			num++;
+			try {
+				Thread.sleep(1000);
+			} catch (InterruptedException e) {
+				throw new RuntimeException(e);
+			}
+			return getCameraShotByFileId2023(fileId, num);
 		}
 		data = data.replaceAll(";", "");
 		return "https://zhyn-pic.cg.gz.gov.cn" + data;
@@ -459,7 +508,7 @@
 		log.info("请求参数:" + JSON.toJSONString(body));
 		post.body(JSON.toJSONString(body));
 		HttpResponse execute = post.execute();
-		if(401 == execute.getStatus()){
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
 			log.error("token失效,重新登录");
 			if(num == 3){
 				log.error("token失效,请联系管理员");
@@ -486,6 +535,49 @@
 	}
 	
 	
+	/**
+	 * 验证当前位置是否在围栏内
+	 * @param longitude
+	 * @param latitude
+	 * @param num
+	 * @return
+	 */
+	public static boolean getFenceByPoint(String longitude, String latitude, int num) {
+		if(null == accountLogin){
+			accountLogin();
+		}
+		HttpRequest post = HttpUtil.createPost("https://zhyn.cg.gz.gov.cn/map/web/getFenceByPoint");
+		post.header("operate-terminal", "4");
+		post.header("token", accountLogin.getToken());
+		Map<String, Object> body = new HashMap<>();
+		body.put("longitude", longitude);
+		body.put("latitude", latitude);
+		body.put("type", "1");
+		log.info("【验证当前位置是否在围栏内】请求参数:" + JSON.toJSONString(body));
+		post.body(JSON.toJSONString(body));
+		HttpResponse execute = post.execute();
+		if(401 == execute.getStatus() || 403 == execute.getStatus()){
+			log.error("token失效,重新登录");
+			if(num == 3){
+				log.error("token失效,请联系管理员");
+				throw new RuntimeException("token失效,请联系管理员");
+			}
+			num++;
+			accountLogin = null;
+			return getFenceByPoint(longitude, latitude, num);
+		}
+		log.info("【验证当前位置是否在围栏内】返回结果:" + execute.body());
+		JSONObject result = JSON.parseObject(execute.body());
+		Integer code = result.getInteger("code");
+		if(0 != code){
+			log.error(result.getString("msg"));
+			throw new RuntimeException("【验证当前位置是否在围栏内】失败:" + execute.body());
+		}
+		Integer data = result.getInteger("data");
+		return 1 == data;
+	}
+	
+	
 	
 	public static void main(String[] args) {
 //		SM4 sm4 = SmUtil.sm4("EP77VsBj9yeOKpcO".getBytes());
@@ -501,8 +593,8 @@
 //		locationRealTimeInfoCache(0);
 		
 		
-		List<Vehicle> 粤AFX998 = VideoGateway.getVehicleList("粤AFX998", null, null, 0);
-		System.err.println(粤AFX998);
+		List<VehicleOnline> vehicleOnlines = queryRuntimeInfoByCache(0);
+		System.err.println(vehicleOnlines);
 	}
 	
 //	public static void main(String[] args) {

--
Gitblit v1.7.1