From c1147646b9ef1d713a202d7ab8cf3ea8d677f142 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期六, 27 九月 2025 21:56:54 +0800
Subject: [PATCH] fix:优化评价

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/GpsCollectServiceImpl.java |  177 ++++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 115 insertions(+), 62 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/GpsCollectServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/GpsCollectServiceImpl.java
index 7c20adb..42e8390 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/GpsCollectServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/GpsCollectServiceImpl.java
@@ -78,6 +78,7 @@
                     response.setSuccess(true);
                     response.setMessage("鐧诲綍鎴愬姛");
                     response.setToken(jsonResult.getString("token"));
+                    response.setServerid(jsonResult.getInteger("serverid"));
                     break;
                 case -1:
                     response.setSuccess(false);
@@ -131,36 +132,60 @@
      * 鑾峰彇鏈夋晥鐨則oken锛屽鏋渢oken鏃犳晥鍒欒嚜鍔ㄧ櫥褰�
      */
     private String getValidTokenWithAutoLogin() {
-        // 鑾峰彇褰撳墠token
-        String token = gpsConfigService.getValidToken("gps51");
-        if (token == null || token.isEmpty()) {
-            //璇诲彇gspconfig涓殑鍩熷悕锛岀敤鎴峰悕锛屽瘑鐮�
-            SysGpsConfig config = gpsConfigService.selectGpsConfigByKey("gps51");
-            if (config == null) {
-                return null;
+        try {
+            // 鑾峰彇褰撳墠token
+            String token = gpsConfigService.getValidToken("gps51");
+            if (token == null || token.isEmpty()) {
+                System.out.println("褰撳墠token鏃犳晥锛屽皾璇曢噸鏂扮櫥褰�");
+                //璇诲彇gspconfig涓殑鍩熷悕锛岀敤鎴峰悕锛屽瘑鐮�
+                SysGpsConfig config = gpsConfigService.selectGpsConfigByKey("gps51");
+                if (config == null) {
+                    System.err.println("GPS閰嶇疆淇℃伅鏈壘鍒帮紝鏃犳硶杩涜鐧诲綍");
+                    return null;
+                }
+                
+                String username = config.getUsername();
+                String password = config.getPassword();
+                String domain = config.getDomain();
+                
+                if (username == null || password == null || domain == null) {
+                    System.err.println("GPS閰嶇疆淇℃伅涓嶅畬鏁达紝鐢ㄦ埛鍚嶃�佸瘑鐮佹垨鍩熷悕涓虹┖");
+                    return null;
+                }
+                
+                // token鏃犳晥锛屽皾璇曠櫥褰�
+                GpsLoginRequest loginRequest = new GpsLoginRequest();
+                loginRequest.setType("USER");
+                loginRequest.setFrom("WEB");
+                loginRequest.setUsername(username);
+                loginRequest.setPassword(password);
+                loginRequest.setDomain(domain);
+                
+                System.out.println("寮�濮嬬櫥褰旼PS绯荤粺锛岀敤鎴峰悕: " + username + ", 鍩熷悕: " + domain);
+                GpsLoginResponse loginResponse = login(loginRequest);
+                
+                if (loginResponse.isSuccess()) {
+                    //灏唗oken鍐欏叆gspconfig
+                    token = loginResponse.getToken();
+                    Integer serviceid = loginResponse.getServerid();
+                    //getTokenExpireTime 杩欎釜鏄病鏈夌殑 闇�瑕佽嚜宸辫绠楋紝褰撳墠鏃堕棿+23灏忔椂
+                    Date expireTime = DateUtils.addHours(new Date(), 23);
+                    gpsConfigService.updateToken("gps51", token,serviceid, expireTime);
+                    System.out.println("GPS绯荤粺鐧诲綍鎴愬姛锛宼oken宸叉洿鏂�");
+                    return token;
+                } else {
+                    System.err.println("GPS绯荤粺鐧诲綍澶辫触: " + loginResponse.getMessage());
+                    return null;
+                }
+            } else {
+                System.out.println("浣跨敤鐜版湁鏈夋晥token");
             }
-            String username = config.getUsername();
-            String password = config.getPassword();
-            String domain = config.getDomain();
-            // token鏃犳晥锛屽皾璇曠櫥褰�
-            GpsLoginRequest loginRequest = new GpsLoginRequest();
-            loginRequest.setType("USER");
-            loginRequest.setFrom("WEB");
-            loginRequest.setUsername(username);
-            loginRequest.setPassword(password);
-            loginRequest.setDomain(domain);
-            GpsLoginResponse loginResponse = login(loginRequest);
-            
-            if (loginResponse.isSuccess()) {
-                //灏唗oken鍐欏叆gspconfig
-                token = loginResponse.getToken();
-                //getTokenExpireTime 杩欎釜鏄病鏈夌殑 闇�瑕佽嚜宸辫绠楋紝褰撳墠鏃堕棿+23灏忔椂
-                Date expireTime = DateUtils.addHours(new Date(), 23);
-                gpsConfigService.updateToken("gps51", token, expireTime);
-                return token;
-            }
+            return token;
+        } catch (Exception e) {
+            System.err.println("鑾峰彇token鏃跺彂鐢熷紓甯�: " + e.getMessage());
+            e.printStackTrace();
+            return null;
         }
-        return token;
     }
 
     /**
@@ -262,7 +287,7 @@
         
         String username = config.getUsername();
         // 鏋勫缓璇锋眰URL
-        String url = config.getDomain() + "/webapi?action=querymonitorlist&token=" + token;
+        String url = config.getDomain() + "/webapi?action=querymonitorlist&token=" + token+"&serverid="+config.getServerid();
         Map<String, String> params = new HashMap<>();
         params.put("username", username);
         
@@ -344,6 +369,7 @@
             response.setCause("鏈壘鍒癎PS閰嶇疆淇℃伅");
             return response;
         }
+        System.out.println("GPS閰嶇疆淇℃伅鑾峰彇鎴愬姛锛�");
 
         // 鑾峰彇鏈夋晥鐨則oken锛屽鏋滄棤鏁堝垯鑷姩鐧诲綍
         String token = getValidTokenWithAutoLogin();
@@ -354,9 +380,12 @@
             return response;
         }
 
+        System.out.println("token鑾峰彇鎴愬姛锛�"+token);
+
         // 鏋勫缓璇锋眰URL
-        String url = config.getDomain() + "/webapi?action=lastposition&token="+token;
-        
+        String url = config.getDomain() + "/webapi?action=lastposition&token="+token+"&serverid="+config.getServerid();
+        System.out.println("璇锋眰URL锛�"+url);
+
         // 鏋勫缓璇锋眰鍙傛暟
         Map<String, String> params = new HashMap<>();
             
@@ -372,6 +401,8 @@
         if (request.getDeviceids() != null && !request.getDeviceids().isEmpty()) {
             params.put("deviceids", JSON.toJSONString(request.getDeviceids()));
         }
+
+        System.out.println("璇锋眰鍙傛暟锛�"+params);
 
         try {
             
@@ -513,39 +544,58 @@
 
     @Override
     public GpsTrackQueryResponse queryTracks(GpsTrackQueryRequest request) {
-        // 鑾峰彇GPS閰嶇疆淇℃伅
-        SysGpsConfig config = gpsConfigService.selectGpsConfigByKey("gps51");
-        if (config == null) {
-            GpsTrackQueryResponse response = new GpsTrackQueryResponse();
-            response.setStatus(-1);
-            response.setCause("鏈壘鍒癎PS閰嶇疆淇℃伅");
-            return response;
-        }
-
-        // 鑾峰彇鏈夋晥鐨則oken锛屽鏋滄棤鏁堝垯鑷姩鐧诲綍
-        String token = getValidTokenWithAutoLogin();
-        if (token == null) {
-            GpsTrackQueryResponse response = new GpsTrackQueryResponse();
-            response.setStatus(-1);
-            response.setCause("鑾峰彇token澶辫触");
-            return response;
-        }
-
-        // 鏋勫缓璇锋眰URL
-        String url = config.getDomain() + "/webapi?action=querytracks&token=" + token;
-        
-        // 鏋勫缓璇锋眰鍙傛暟
-        Map<String, String> params = new HashMap<>();
-        params.put("deviceid", request.getDeviceid());
-        params.put("begintime", request.getBegintime());
-        params.put("endtime", request.getEndtime());
-        if (request.getTimezone() != null) {
-            params.put("timezone", String.valueOf(request.getTimezone()));
-        }
-
         try {
+            // 鑾峰彇GPS閰嶇疆淇℃伅
+            SysGpsConfig config = gpsConfigService.selectGpsConfigByKey("gps51");
+            if (config == null) {
+                System.err.println("GPS閰嶇疆淇℃伅鏈壘鍒帮紝configKey: gps51");
+                GpsTrackQueryResponse response = new GpsTrackQueryResponse();
+                response.setStatus(-1);
+                response.setCause("鏈壘鍒癎PS閰嶇疆淇℃伅");
+                return response;
+            }
+            
+            System.out.println("GPS閰嶇疆淇℃伅鑾峰彇鎴愬姛锛屽煙鍚�: " + config.getDomain() + ", 鐢ㄦ埛鍚�: " + config.getUsername());
+
+            // 鑾峰彇鏈夋晥鐨則oken锛屽鏋滄棤鏁堝垯鑷姩鐧诲綍
+            String token = getValidTokenWithAutoLogin();
+            if (token == null) {
+                System.err.println("鑾峰彇token澶辫触");
+                GpsTrackQueryResponse response = new GpsTrackQueryResponse();
+                response.setStatus(-1);
+                response.setCause("鑾峰彇token澶辫触");
+                return response;
+            }
+            
+            System.out.println("Token鑾峰彇鎴愬姛: " + token);
+
+            // 鏋勫缓璇锋眰URL
+            String url = config.getDomain() + "/webapi?action=querytracks&token=" + token+"&serverid="+config.getServerid();
+            System.out.println("璇锋眰URL: " + url);
+            
+            // 鏋勫缓璇锋眰鍙傛暟
+            Map<String, String> params = new HashMap<>();
+            params.put("deviceid", request.getDeviceid());
+            params.put("begintime", request.getBegintime());
+            params.put("endtime", request.getEndtime());
+            if (request.getTimezone() != null) {
+                params.put("timezone", String.valueOf(request.getTimezone()));
+            }
+            
+            System.out.println("璇锋眰鍙傛暟: " + params);
+
             // 鍙戦�丠TTP璇锋眰
             String result = HttpUtil.post(url, params);
+            System.out.println("HTTP鍝嶅簲缁撴灉: " + result);
+            
+            if (result == null || result.trim().isEmpty()) {
+                System.err.println("HTTP璇锋眰杩斿洖绌虹粨鏋�");
+                GpsTrackQueryResponse response = new GpsTrackQueryResponse();
+                response.setStatus(-1);
+                response.setCause("HTTP璇锋眰杩斿洖绌虹粨鏋�");
+                return response;
+            }
+            
             JSONObject jsonResult = JSON.parseObject(result);
 
             // 瑙f瀽鍝嶅簲
@@ -555,6 +605,7 @@
             response.setDeviceid(jsonResult.getString("deviceid"));
 
             if (response.getStatus() == 0) {
+
                 // 瑙f瀽杞ㄨ抗璁板綍鍒楄〃
                 JSONArray recordsArray = jsonResult.getJSONArray("records");
                 List<GpsTrackPoint> records = new ArrayList<>();
@@ -592,9 +643,11 @@
 
             return response;
         } catch (Exception e) {
+            System.err.println("鏌ヨ鍘嗗彶杞ㄨ抗寮傚父: " + e.getMessage());
+            e.printStackTrace();
             GpsTrackQueryResponse response = new GpsTrackQueryResponse();
             response.setStatus(-1);
-            response.setCause("鏌ヨ鍘嗗彶杞ㄨ抗澶辫触锛�" + e.getMessage());
+            response.setCause("鏌ヨ鍘嗗彶杞ㄨ抗澶辫触锛�" + (e.getMessage() != null ? e.getMessage() : e.getClass().getSimpleName()));
             return response;
         }
     }

--
Gitblit v1.9.1