From d4e4ea6405756d495806a609e24ae85ebd7345ef Mon Sep 17 00:00:00 2001 From: suerprisePlus <15810472099@163.com> Date: 星期二, 17 十二月 2024 09:30:12 +0800 Subject: [PATCH] 代码更新 --- src/main/java/com/yb/service/AgentService.java | 75 ++++++++++++++++++++++++++++++++----- 1 files changed, 64 insertions(+), 11 deletions(-) diff --git a/src/main/java/com/yb/service/AgentService.java b/src/main/java/com/yb/service/AgentService.java index 6107210..a1b1943 100644 --- a/src/main/java/com/yb/service/AgentService.java +++ b/src/main/java/com/yb/service/AgentService.java @@ -3,7 +3,7 @@ import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.yb.config.XzConfig; -import com.yb.entity.ReqEntity; +import com.yb.entity.RelaEntity; import com.yb.util.EntityHttpUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -29,8 +29,8 @@ return obj; } - public String getAgentIntention(String url, String api, String msg) throws Exception { - String http = url + api + "?message=" + msg; + public String getAgentIntention(String url, String api, String msg, String sessionid, String libid) throws Exception { + String http = url + api + "?session_id=" + sessionid + "&lib_id=" + libid + "&message=" + msg; System.out.println("rec getMessage:" + http); String obj = entityHttpUtil.getAgentMessage(http); System.out.println("rec getMessage:" + obj); @@ -48,6 +48,9 @@ public String getAgentAroundPoi(String place, String type, int dis, String filed, String typeFiled) throws Exception { String item = xzService.getQueryFiled(place, filed, xzConfig.layerId, xzConfig.dbid, xzConfig.queryEntity); JSONObject obj = JSONObject.parseObject(item); + if (obj == null) { + return ""; + } Double lon = Double.parseDouble(obj.getString("lon")); Double lat = Double.parseDouble(obj.getString("lat")); String wkt = xzService.getWKt(lon, lat, dis); @@ -57,6 +60,12 @@ public HashMap<String, Object> getQueryRelationship(String place, String filed) throws Exception { String poiObj = xzService.getQueryEntity(place, filed, xzConfig.layerId, xzConfig.dbid, xzConfig.layerQuery); + + if (poiObj == null) { + HashMap<String, Object> hashMap = new HashMap<>(); + hashMap.put("msg", "鏈煡璇㈠埌" + place + "鐩稿叧鏁版嵁"); + return hashMap; + } HashMap<String, String> hashMap = new HashMap<String, String>(); hashMap.put("token", xzConfig.token); hashMap.put("dbid", xzConfig.dbid); @@ -69,15 +78,18 @@ for (int i = 0; i < relationArry.size(); i++) { JSONObject relationtem = relationArry.getJSONObject(i); String name = relationtem.getString("name"); - if (name.equals("鍖呭惈鍏崇郴")) { +// if (name.equals("鍖呭惈")) { +// itemObj = relationtem; +// } + if (name.contains(String.valueOf("鍖呭惈"))) { itemObj = relationtem; } } - String distanceUrl = xzConfig.relationDistinct + "?dbid=" + xzConfig.dbid + "&token=" + xzConfig.token + "&relationid=" + itemObj.getString("code"); - String relationDistance = entityHttpUtil.getMessage(distanceUrl); - JSONObject distanceObj = JSONObject.parseObject(relationList); - String distanceData = relattionObj.getString("data"); - System.out.println("rec getQueryRelationship:" + distanceData); +// String distanceUrl = xzConfig.relationDistinct + "?dbid=" + xzConfig.dbid + "&token=" + xzConfig.token + "&relationid=" + itemObj.getString("code"); +// String relationDistance = entityHttpUtil.getMessage(distanceUrl); +// JSONObject distanceObj = JSONObject.parseObject(relationList); +// String distanceData = relattionObj.getString("data"); +// System.out.println("rec getQueryRelationship:" + distanceData); String relateddataeUrl = xzConfig.relationRelateddata + "?start=1&count=1000000&&a_like=&b_like=&dbid=" + xzConfig.dbid + "&token=" + xzConfig.token + "&relationid=" + itemObj.getString("code"); String relationRelateddata = entityHttpUtil.getMessage(relateddataeUrl); @@ -94,7 +106,7 @@ HashMap<String, String> reMap = new HashMap<String, String>(); reMap.put("token", xzConfig.token); reMap.put("dbid", xzConfig.dbid); - reMap.put("businessids", list.toString()); + reMap.put("ids", list.toString()); reMap.put("layerid", xzConfig.layerId); reMap.put("querylatest", "true"); String reMapList = entityHttpUtil.getPostMessage(xzConfig.layerQuery, reMap); @@ -103,7 +115,48 @@ HashMap<String, Object> traiMap = new HashMap<>(); traiMap.put("center", JSONObject.parseObject(poiObj)); traiMap.put("positions", reArray); - System.out.println("rec getQueryRelationship:" + traiMap); + if (reArray.size() > 0) { + ArrayList<RelaEntity> arrayList = new ArrayList<>(); + for (int i = 0; i < reArray.size(); i++) { + + String name = JSONObject.parseObject(reArray.getString(i)).getString(xzConfig.typeFiled); +// System.out.println("rec getQueryRelationship:" + name); + if (name == null || name.isEmpty()) { + continue; + } else { + + if (name.equals(place)) { + continue; + } + boolean contains = false; + for (int j = 0; j < arrayList.size(); j++) { + RelaEntity firstElement = arrayList.get(j); + if (firstElement.getName().equals(name)) { + int flag = firstElement.getCount(); + flag++; + firstElement.setCount(flag); + contains = true; + } + } + if (contains == false) { + RelaEntity relaEntity = new RelaEntity(); + relaEntity.setName(name); + relaEntity.setCount(1); + arrayList.add(relaEntity); + } + } + } + String markDown = "| 鏁版嵁绫诲瀷 | 鏁版嵁閲� |\n|------|------|\n"; + for (int i = 0; i < arrayList.size(); i++) { + String name = arrayList.get(i).getName(); + int count = arrayList.get(i).getCount(); + markDown += "| " + name + " | " + count + " |\n"; + + } + traiMap.put("msg", markDown); + } + +// System.out.println("rec traiMap:" + traiMap); return traiMap; } -- Gitblit v1.9.3