From 7c2578e6a5b451a4c1c129b678b23cdb36c1620f Mon Sep 17 00:00:00 2001
From: zhangjian <zhangjianrock@163.com>
Date: 星期二, 11 七月 2023 11:52:26 +0800
Subject: [PATCH] 无人机转发接口
---
/dev/null | 9 ---
ard-work/src/main/java/com/ruoyi/device/uav/controller/ArdUavController.java | 92 ++----------------------------
ard-work/src/main/java/com/ruoyi/utils/forest/UavAuthLifeCircle.java | 24 --------
ard-work/src/main/java/com/ruoyi/device/uav/service/UavService.java | 15 +---
4 files changed, 11 insertions(+), 129 deletions(-)
diff --git a/ard-work/src/main/java/com/ruoyi/device/uav/controller/ArdUavController.java b/ard-work/src/main/java/com/ruoyi/device/uav/controller/ArdUavController.java
index feb37e3..07d1185 100644
--- a/ard-work/src/main/java/com/ruoyi/device/uav/controller/ArdUavController.java
+++ b/ard-work/src/main/java/com/ruoyi/device/uav/controller/ArdUavController.java
@@ -6,6 +6,7 @@
import com.fasterxml.jackson.databind.ObjectMapper;
import com.github.pagehelper.util.StringUtil;
import com.ruoyi.common.core.controller.BaseController;
+import com.ruoyi.device.uav.service.UavService;
import com.ruoyi.utils.forest.UavClient;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
@@ -38,115 +39,34 @@
@RequestMapping("/device/uav")
@Api(tags = "鏃犱汉鏈哄閮ㄦ帴鍙�")
public class ArdUavController extends BaseController {
- public static final String USERNAME = "ardbailu";//鐢ㄦ埛鍚�
- public static final String PASSWORD = "ardkj12345";//瀵嗙爜
- public static final String SALT = "0123456789012345";//鐩�
-
- //token 鐧婚檰鍚庢瘡娆¤姹�,鍦╤eader涓惡甯�
- private String token;//鐧诲綍鎴愬姛杩斿洖鐨則oken
- private ObjectMapper om = new ObjectMapper();
@Autowired
- private UavClient uavClient;
+ private UavService uavService;
@PostConstruct
public void created() {
- this.uavLogin();
+ this.uavService.login();
}
- public void uavLogin() {
- String codedPassword = this.Encrypt(PASSWORD, SALT);
- String body = "{\"username\":\"" + USERNAME + "\",\"password\":\"" + codedPassword + "\"}";
- try {
- String res = uavClient.POST("login", null, body);
- Map resMap = om.readValue(res, Map.class);
- Map data = (Map) resMap.get("data");
- if (data != null) {
- this.token = (String) data.get("access_token");
- }
- } catch (ForestNetworkException e) {
- e.printStackTrace();
- } catch (JsonMappingException e) {
- throw new RuntimeException(e);
- } catch (JsonProcessingException e) {
- throw new RuntimeException(e);
- }
- }
@GetMapping("/")
@ApiOperation("鏃犱汉鏈篻et鎺ュ彛")
public Object get(@RequestParam String url, @RequestParam String data) {
- return doUavRequest(GET, url, data);
+ return this.uavService.doUavRequest(GET, url, data);
}
@PostMapping("/")
@ApiOperation("鏃犱汉鏈簆ost鎺ュ彛")
public Object post(@RequestParam String url, @RequestParam String data) {
- return doUavRequest(POST, url, data);
+ return this.uavService.doUavRequest(POST, url, data);
}
@DeleteMapping("/")
@ApiOperation("鏃犱汉鏈篸elete鎺ュ彛")
public Object delete(@RequestParam String url, @RequestParam String data) {
- return doUavRequest(DELETE, url, data);
+ return this.uavService.doUavRequest(DELETE, url, data);
}
- @Nullable
- private String doUavRequest(HttpMethod method, String url, String data) {
- String res = null;
- Method requestMethod = null;
- //鑾峰彇method
- try {
- requestMethod = UavClient.class.getMethod(method.name(), String.class, String.class, String.class);
- } catch (NoSuchMethodException e) {
- e.printStackTrace();
- }
- //鎵цmethod
- try {
- res = (String) requestMethod.invoke(this.uavClient, url, this.token, data);
- } catch (InvocationTargetException e) {
- ForestNetworkException fe = (ForestNetworkException) e.getCause();
- if (fe.getStatusCode() == 401) {//token澶辨晥,閲嶆柊鐧诲綍
- this.uavLogin();
- }
- try {//鍐嶆璋冪敤鎺ュ彛
- res = (String) requestMethod.invoke(this.uavClient, url, this.token, data);
- } catch (IllegalAccessException ex) {
- throw new RuntimeException(ex);
- } catch (InvocationTargetException ex) {
- throw new RuntimeException(ex);
- }
- } catch (IllegalAccessException e) {
- throw new RuntimeException(e);
- }
-
- return res;
- }
-
-
- public String Encrypt(String sSrc, String sKey) {
- if (sKey == null) {
- System.out.print("Key涓虹┖null");
- return null;
- }
- // 鍒ゆ柇Key鏄惁涓�16浣�
- if (sKey.length() != 16) {
- System.out.print("Key闀垮害涓嶆槸16浣�");
- return null;
- }
- byte[] encrypted = null;
- try {
- byte[] raw = sKey.getBytes("utf-8");
- SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
- Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");//"绠楁硶/妯″紡/琛ョ爜鏂瑰紡"
- cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
- encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));
- } catch (Exception e) {
- e.printStackTrace();
- ;
- }
- return new Base64().encodeToString(encrypted);//姝ゅ浣跨敤BASE64鍋氳浆鐮佸姛鑳斤紝鍚屾椂鑳借捣鍒�2娆″姞瀵嗙殑浣滅敤銆�
- }
}
diff --git a/ard-work/src/main/java/com/ruoyi/device/uav/service/IUavService.java b/ard-work/src/main/java/com/ruoyi/device/uav/service/IUavService.java
deleted file mode 100644
index a9e8893..0000000
--- a/ard-work/src/main/java/com/ruoyi/device/uav/service/IUavService.java
+++ /dev/null
@@ -1,9 +0,0 @@
-package com.ruoyi.device.uav.service;
-
-import org.springframework.http.HttpMethod;
-
-public interface IUavService {
- String doUavRequest(HttpMethod method, String url, String data);
-
- void login();
-}
diff --git a/ard-work/src/main/java/com/ruoyi/device/uav/service/UavService.java b/ard-work/src/main/java/com/ruoyi/device/uav/service/UavService.java
index 1950bfd..026c3bd 100644
--- a/ard-work/src/main/java/com/ruoyi/device/uav/service/UavService.java
+++ b/ard-work/src/main/java/com/ruoyi/device/uav/service/UavService.java
@@ -20,7 +20,7 @@
import java.util.Map;
@Service
-public class UavService implements IUavService {
+public class UavService {
public static final String USERNAME = "ardbailu";//鐢ㄦ埛鍚�
public static final String PASSWORD = "ardkj12345";//瀵嗙爜
public static final String SALT = "0123456789012345";//鐩�
@@ -36,7 +36,6 @@
this.login();
}
- @Override
public String doUavRequest(HttpMethod method, String url, String data) {
String res = null;
Method requestMethod = null;
@@ -57,9 +56,9 @@
try {//鍐嶆璋冪敤鎺ュ彛
res = (String) requestMethod.invoke(this.uavClient, url, this.token, data);
} catch (IllegalAccessException ex) {
- throw new RuntimeException(ex);
+ ex.printStackTrace();
} catch (InvocationTargetException ex) {
- throw new RuntimeException(ex);
+ ex.printStackTrace();
}
} catch (IllegalAccessException e) {
throw new RuntimeException(e);
@@ -68,7 +67,6 @@
return res;
}
- @Override
public void login() {
String codedPassword = this.Encrypt(PASSWORD, SALT);
String body = "{\"username\":\"" + USERNAME + "\",\"password\":\"" + codedPassword + "\"}";
@@ -82,21 +80,19 @@
} catch (ForestNetworkException e) {
e.printStackTrace();
} catch (JsonMappingException e) {
- throw new RuntimeException(e);
+ e.printStackTrace();
} catch (JsonProcessingException e) {
- throw new RuntimeException(e);
+ e.printStackTrace();
}
}
public String Encrypt(String sSrc, String sKey) {
if (sKey == null) {
- System.out.print("Key涓虹┖null");
return null;
}
// 鍒ゆ柇Key鏄惁涓�16浣�
if (sKey.length() != 16) {
- System.out.print("Key闀垮害涓嶆槸16浣�");
return null;
}
byte[] encrypted = null;
@@ -108,7 +104,6 @@
encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));
} catch (Exception e) {
e.printStackTrace();
- ;
}
return new Base64().encodeToString(encrypted);//姝ゅ浣跨敤BASE64鍋氳浆鐮佸姛鑳斤紝鍚屾椂鑳借捣鍒�2娆″姞瀵嗙殑浣滅敤銆�
}
diff --git a/ard-work/src/main/java/com/ruoyi/utils/forest/UavAuthLifeCircle.java b/ard-work/src/main/java/com/ruoyi/utils/forest/UavAuthLifeCircle.java
index 83aea24..f010584 100644
--- a/ard-work/src/main/java/com/ruoyi/utils/forest/UavAuthLifeCircle.java
+++ b/ard-work/src/main/java/com/ruoyi/utils/forest/UavAuthLifeCircle.java
@@ -7,25 +7,6 @@
public class UavAuthLifeCircle implements MethodAnnotationLifeCycle<UavAuth, Object> {
- /**
- * 褰撴柟娉曡皟鐢ㄦ椂璋冪敤姝ゆ柟娉曪紝姝ゆ椂杩樻病鏈夋墽琛岃姹傚彂閫�
- * 娆℃柟娉曞彲浠ヨ幏寰楄姹傚搴旂殑鏂规硶璋冪敤淇℃伅锛屼互鍙婂姩鎬佷紶鍏ョ殑鏂规硶璋冪敤鍙傛暟鍒楄〃
- */
- @Override
- public void onInvokeMethod(ForestRequest request, ForestMethod method, Object[] args) {
-
- System.out.println("!!!!!onInvokeMethod!!!!!! '" + method.getMethodName() + "' Arguments>>>>>>>>>: ");
- /* for (Object arg :
- args) {
- System.out.println(arg);
- }
- String token = (String) args[1];
- if (token != null) {
- request.addHeader("x-auth-token", token);
- }*/
-
- System.out.println("=================");
- }
/**
* 鍙戦�佽姹傚墠鎵ц姝ゆ柟娉�
@@ -33,10 +14,6 @@
@Override
public boolean beforeExecute(ForestRequest request) {
String token = (String) getAttribute(request, "token");
- System.out.println("!!!!beforeExecute!!!!");
- System.out.println("request.getMethod().getMethodName():" + request.getMethod().getMethodName());
- System.out.println(" token:" + token);
- System.out.println("=================");
request.addHeader("x-auth-token", token);
return true;
}
@@ -47,6 +24,5 @@
@Override
public void onMethodInitialized(ForestMethod forestMethod, UavAuth uavAuth) {
- System.out.println("Method '" + forestMethod.getMethodName());
}
}
--
Gitblit v1.9.3