From b5b16a26de0d84d7b5fb69b584377bdc3582e3ab Mon Sep 17 00:00:00 2001 From: wlzboy <66905212@qq.com> Date: 星期日, 21 九月 2025 20:43:08 +0800 Subject: [PATCH] feat: 更新评价功能 --- 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