From ce64e667815b39efdc2f8bd52be0d43d49db8d84 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期日, 17 七月 2022 00:06:29 +0800
Subject: [PATCH] 优化小区位置
---
service-api/src/main/java/com/java110/api/smo/AppAbstractComponentSMO.java | 193 +++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 180 insertions(+), 13 deletions(-)
diff --git a/service-api/src/main/java/com/java110/api/smo/AppAbstractComponentSMO.java b/service-api/src/main/java/com/java110/api/smo/AppAbstractComponentSMO.java
index cd865a0..90a69df 100644
--- a/service-api/src/main/java/com/java110/api/smo/AppAbstractComponentSMO.java
+++ b/service-api/src/main/java/com/java110/api/smo/AppAbstractComponentSMO.java
@@ -1,26 +1,27 @@
package com.java110.api.smo;
+import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.java110.core.component.AbstractComponentSMO;
import com.java110.core.context.IPageData;
import com.java110.api.properties.WechatAuthProperties;
+import com.java110.core.factory.GenerateCodeFactory;
import com.java110.utils.constant.CommonConstant;
import com.java110.utils.constant.ResponseConstant;
import com.java110.utils.constant.ServiceCodeConstant;
import com.java110.utils.constant.ServiceConstant;
import com.java110.utils.exception.SMOException;
-import com.java110.utils.util.Assert;
-import com.java110.utils.util.StringUtil;
-import com.java110.utils.util.UrlParamToJsonUtil;
+import com.java110.utils.factory.ApplicationContextFactory;
+import com.java110.utils.util.*;
+import com.java110.vo.ResultVo;
import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import com.java110.core.log.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.*;
import org.springframework.web.client.HttpStatusCodeException;
import org.springframework.web.client.RestTemplate;
-import java.util.HashMap;
-import java.util.Map;
+import java.util.*;
public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
@@ -46,7 +47,79 @@
private static final String WECHAT_SERVICE_MCH_ID = "SERVICE_MCH_ID";
+ /**
+ * 璋冪敤涓績鏈嶅姟
+ *
+ * @return
+ */
+ protected ResponseEntity<String> callCenterService(Map<String, String> headers, String param, String url, HttpMethod httpMethod) {
+ ResponseEntity<String> responseEntity = null;
+ if (StringUtil.isEmpty(param)) {
+ param = UrlParamToJsonUtil.getJson(url).toJSONString();
+ }
+
+ if (!headers.containsKey(CommonConstant.HTTP_USER_ID)) {
+ headers.put(CommonConstant.HTTP_USER_ID, "-1");
+ }
+
+ headers.put(CommonConstant.USER_ID, "-1");
+
+ if (!headers.containsKey(CommonConstant.HTTP_USER_ID)) {
+ headers.put(CommonConstant.HTTP_USER_ID, "-1");
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_TRANSACTION_ID)) {
+ headers.put(CommonConstant.HTTP_TRANSACTION_ID, GenerateCodeFactory.getUUID());
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_REQ_TIME)) {
+ headers.put(CommonConstant.HTTP_REQ_TIME, DateUtil.getNowDefault());
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_SIGN)) {
+ headers.put(CommonConstant.HTTP_SIGN, "");
+ }
+
+ if (url.indexOf("?") > -1) {
+ url = url.substring(0, url.indexOf("?"));
+ }
+ headers.put(CommonConstant.HTTP_SERVICE, url);
+ headers.put(CommonConstant.HTTP_METHOD, CommonConstant.getHttpMethodStr(httpMethod));
+
+ if (HttpMethod.GET == httpMethod) {
+ initUrlParam(JSONObject.parseObject(param), headers);
+ }
+ if (HttpMethod.GET == httpMethod) {
+ headers.put("REQUEST_URL", "http://127.0.0.1:8008/" + url + mapToUrlParam(JSONObject.parseObject(param)));
+ }
+ try {
+ responseEntity = apiServiceSMOImpl.service(param, headers);
+ } catch (HttpStatusCodeException e) { //杩欓噷spring 妗嗘灦 鍦�4XX 鎴� 5XX 鏃舵姏鍑� HttpServerErrorException 寮傚父锛岄渶瑕侀噸鏂板皝瑁呬竴涓�
+ responseEntity = new ResponseEntity<String>(e.getResponseBodyAsString(), e.getStatusCode());
+ } catch (Exception e) {
+ responseEntity = new ResponseEntity<String>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
+ } finally {
+ logger.debug("璇锋眰鍦板潃涓�,{} 璇锋眰涓績鏈嶅姟淇℃伅锛寋},涓績鏈嶅姟杩斿洖淇℃伅锛寋}", url, param, responseEntity);
+ }
+ return responseEntity;
+ }
+
+ /**
+ * 灏唘rl鍙傛暟鍐欏埌header map涓�
+ *
+ * @param paramIn
+ */
+ protected void initUrlParam(Map paramIn, Map headers) {
+ /*put real ip address*/
+
+ if (paramIn != null && !paramIn.isEmpty()) {
+ Set<String> keys = paramIn.keySet();
+ for (Iterator it = keys.iterator(); it.hasNext(); ) {
+ String key = (String) it.next();
+ headers.put(key, paramIn.get(key));
+ }
+ }
+
+
+ }
/**
* 璋冪敤涓績鏈嶅姟
*
@@ -69,8 +142,18 @@
if (!headers.containsKey(CommonConstant.HTTP_USER_ID)) {
headers.put(CommonConstant.HTTP_USER_ID, StringUtil.isEmpty(pd.getUserId()) ? "-1" : pd.getUserId());
}
-
- headers.put(CommonConstant.USER_ID, StringUtil.isEmpty(pd.getUserId()) ? "-1" : pd.getUserId());
+ if (!headers.containsKey(CommonConstant.HTTP_APP_ID)) {
+ headers.put(CommonConstant.HTTP_APP_ID, pd.getAppId());
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_TRANSACTION_ID)) {
+ headers.put(CommonConstant.HTTP_TRANSACTION_ID, pd.getTransactionId());
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_REQ_TIME)) {
+ headers.put(CommonConstant.HTTP_REQ_TIME, pd.getRequestTime());
+ }
+ if (!headers.containsKey(CommonConstant.HTTP_SIGN)) {
+ headers.put(CommonConstant.HTTP_SIGN, "");
+ }
if (url.indexOf("?") > -1) {
url = url.substring(0, url.indexOf("?"));
@@ -102,7 +185,7 @@
protected ResponseEntity<String> getUserInfo(IPageData pd, RestTemplate restTemplate) {
Assert.hasLength(pd.getUserId(), "鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
ResponseEntity<String> responseEntity = null;
- responseEntity = this.callCenterService(restTemplate, pd, "", ServiceConstant.SERVICE_API_URL + "/api/query.user.userInfo?userId=" + pd.getUserId(), HttpMethod.GET);
+ responseEntity = this.callCenterService(restTemplate, pd, "", "query.user.userInfo?userId=" + pd.getUserId(), HttpMethod.GET);
// 杩囨护杩斿洖鎶ユ枃涓殑瀛楁锛屽彧杩斿洖name瀛楁
//{"address":"","orderTypeCd":"Q","serviceCode":"","responseTime":"20190401194712","sex":"","localtionCd":"","userId":"302019033054910001","levelCd":"00","transactionId":"-1","dataFlowId":"-1","response":{"code":"0000","message":"鎴愬姛"},"name":"996icu","tel":"18909780341","bId":"-1","businessType":"","email":""}
@@ -121,7 +204,7 @@
//Assert.hasLength(pd.getUserId(), "鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
ResponseEntity<String> responseEntity = null;
responseEntity = this.callCenterService(restTemplate, pd, "",
- ServiceConstant.SERVICE_API_URL + "/api/user.listUsers?openId=" + openId + "&page=1&row=1", HttpMethod.GET);
+ "user.listUsers?openId=" + openId + "&page=1&row=1", HttpMethod.GET);
// 杩囨护杩斿洖鎶ユ枃涓殑瀛楁锛屽彧杩斿洖name瀛楁
//{"address":"","orderTypeCd":"Q","serviceCode":"","responseTime":"20190401194712","sex":"","localtionCd":"","userId":"302019033054910001","levelCd":"00","transactionId":"-1","dataFlowId":"-1","response":{"code":"0000","message":"鎴愬姛"},"name":"996icu","tel":"18909780341","bId":"-1","businessType":"","email":""}
@@ -144,7 +227,7 @@
paramIn.put("row", "1");
}
responseEntity = this.callCenterService(restTemplate, pd, "",
- ServiceConstant.SERVICE_API_URL + "/api/user.listUsers" + mapToUrlParam(paramIn), HttpMethod.GET);
+ "user.listUsers" + mapToUrlParam(paramIn), HttpMethod.GET);
// 杩囨护杩斿洖鎶ユ枃涓殑瀛楁锛屽彧杩斿洖name瀛楁
//{"address":"","orderTypeCd":"Q","serviceCode":"","responseTime":"20190401194712","sex":"","localtionCd":"","userId":"302019033054910001","levelCd":"00","transactionId":"-1","dataFlowId":"-1","response":{"code":"0000","message":"鎴愬姛"},"name":"996icu","tel":"18909780341","bId":"-1","businessType":"","email":""}
return responseEntity;
@@ -166,7 +249,7 @@
paramIn.put("row", "1");
}
responseEntity = this.callCenterService(restTemplate, pd, "",
- ServiceConstant.SERVICE_API_URL + "/api/" + ServiceCodeConstant.LIST_APPUSERBINDINGOWNERS + mapToUrlParam(paramIn), HttpMethod.GET);
+ ServiceCodeConstant.LIST_APPUSERBINDINGOWNERS + mapToUrlParam(paramIn), HttpMethod.GET);
// 杩囨护杩斿洖鎶ユ枃涓殑瀛楁锛屽彧杩斿洖name瀛楁
//{"address":"","orderTypeCd":"Q","serviceCode":"","responseTime":"20190401194712","sex":"","localtionCd":"","userId":"302019033054910001","levelCd":"00","transactionId":"-1","dataFlowId":"-1","response":{"code":"0000","message":"鎴愬姛"},"name":"996icu","tel":"18909780341","bId":"-1","businessType":"","email":""}
return responseEntity;
@@ -187,7 +270,7 @@
}
for (String privilegeCode : privilegeCodes) {
responseEntity = this.callCenterService(restTemplate, pd, "", ServiceConstant.SERVICE_API_URL
- + "/api/check.user.hasPrivilege?userId=" + pd.getUserId() + "&pId=" + privilegeCode, HttpMethod.GET);
+ + "check.user.hasPrivilege?userId=" + pd.getUserId() + "&pId=" + privilegeCode, HttpMethod.GET);
if (responseEntity.getStatusCode() == HttpStatus.OK) {
//throw new SMOException(ResponseConstant.RESULT_CODE_ERROR, "鐢ㄦ埛娌℃湁鏉冮檺鎿嶄綔鏉冮檺" + privilegeCodes);
break;
@@ -199,5 +282,89 @@
}
}
+ /**
+ * 鏌ヨ
+ *
+ * @param pd 椤甸潰瀵硅薄
+ * @param param 浼犲叆瀵硅薄
+ * @param serviceCode 鏈嶅姟缂栫爜
+ * @param t 杩斿洖绫�
+ * @param <T>
+ * @return
+ */
+ protected <T> List<T> postForApis(IPageData pd, T param, String serviceCode, Class<T> t) {
+
+ String url = serviceCode;
+
+ ResponseEntity<String> responseEntity = callCenterService(null, pd, JSONObject.toJSONString(param), url, HttpMethod.POST);
+
+ if (responseEntity.getStatusCode() != HttpStatus.OK) {
+ throw new SMOException("璋冪敤" + serviceCode + "澶辫触锛�" + responseEntity.getBody());
+ }
+
+ JSONObject resultVo = JSONObject.parseObject(responseEntity.getBody());
+
+ if (ResultVo.CODE_MACHINE_OK != resultVo.getInteger("code")) {
+ throw new SMOException(resultVo.getString("msg"));
+ }
+
+ Object bObj = resultVo.get("data");
+ JSONArray datas = null;
+ if (bObj instanceof JSONObject) {
+ datas = new JSONArray();
+ datas.add(bObj);
+ } else {
+ datas = (JSONArray) bObj;
+ }
+ String jsonStr = JSONObject.toJSONString(datas);
+
+ List<T> list = JSONObject.parseArray(jsonStr, t);
+ return list;
+ }
+
+ /**
+ * 鏌ヨ
+ *
+ * @param pd 椤甸潰瀵硅薄
+ * @param param 浼犲叆瀵硅薄
+ * @param serviceCode 鏈嶅姟缂栫爜
+ * @param t 杩斿洖绫�
+ * @param <T>
+ * @return
+ */
+ public <T> List<T> getForApis(IPageData pd, T param, String serviceCode, Class<T> t) {
+
+ String url = serviceCode;
+ if (param != null) {
+ url += mapToUrlParam(BeanConvertUtil.beanCovertMap(param));
+ }
+ RestTemplate restTemplate = ApplicationContextFactory.getBean("restTemplate", RestTemplate.class);
+
+ ResponseEntity<String> responseEntity = callCenterService(restTemplate, pd, "", url, HttpMethod.GET);
+
+ if (responseEntity.getStatusCode() != HttpStatus.OK) {
+ throw new SMOException("璋冪敤" + serviceCode + "澶辫触锛�" + responseEntity.getBody());
+ }
+
+ JSONObject resultVo = JSONObject.parseObject(responseEntity.getBody());
+
+ if (!"0".equals(resultVo.getString("code"))) {
+ throw new SMOException(resultVo.getString("msg"));
+ }
+
+ Object bObj = resultVo.get("data");
+ JSONArray datas = null;
+ if (bObj instanceof JSONObject) {
+ datas = new JSONArray();
+ datas.add(bObj);
+ } else {
+ datas = (JSONArray) bObj;
+ }
+ String jsonStr = JSONObject.toJSONString(datas);
+
+ List<T> list = JSONObject.parseArray(jsonStr, t);
+ return list;
+ }
+
}
--
Gitblit v1.8.0