package com.java110.core.factory; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.java110.core.context.IPageData; import com.java110.core.context.PageData; import com.java110.core.log.LoggerFactory; import com.java110.dto.app.AppDto; import com.java110.utils.constant.CommonConstant; import com.java110.utils.exception.SMOException; import com.java110.utils.factory.ApplicationContextFactory; import com.java110.utils.util.BeanConvertUtil; import com.java110.utils.util.DateUtil; import com.java110.utils.util.StringUtil; import com.java110.vo.ResultVo; import org.slf4j.Logger; 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.List; import java.util.Map; public class CallApiServiceFactory { private static final String URL_API = "http://api-service/api/"; //日志 private static Logger logger = LoggerFactory.getLogger(CallApiServiceFactory.class); @Autowired private RestTemplate restTemplate; /** * 查询 * * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ public static T getForApi(String appId, T param, String serviceCode, Class t) { IPageData pd = PageData.newInstance().builder("-1", "未知", "", "", "", "", "", "", appId); List list = getForApis(pd, param, serviceCode, t); if (list != null && list.size() > 0) { return list.get(0); } return null; } /** * 查询 * * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ public static T postForApi(String appId, T param, String serviceCode, Class t, String userId) { IPageData pd = PageData.newInstance().builder(userId, "未知", "", "", "", "", "", "", appId); List ts = postForApis(pd, param, serviceCode, t); if (ts == null || ts.size() < 1) { return null; } return ts.get(0); } /** * 查询 * * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ public static T postForApi(String appId, T param, String serviceCode, Class t) { return postForApi(appId, param, serviceCode, t, "-1"); } /** * 查询 * * @param pd 页面对象 * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ public static T getForApi(IPageData pd, T param, String serviceCode, Class t) { List list = getForApis(pd, param, serviceCode, t); if (list != null && list.size() > 0) { return list.get(0); } return null; } /** * 查询 * * @param pd 页面对象 * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ protected T postForApi(IPageData pd, T param, String serviceCode, Class t) { List ts = postForApis(pd, param, serviceCode, t); if (ts == null || ts.size() < 1) { return null; } return ts.get(0); } /** * 查询 * * @param pd 页面对象 * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ protected static List postForApis(IPageData pd, T param, String serviceCode, Class t) { String url = URL_API + serviceCode; RestTemplate restTemplate = ApplicationContextFactory.getBean("restTemplate", RestTemplate.class); ResponseEntity responseEntity = callCenterService(restTemplate, 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 list = JSONObject.parseArray(jsonStr, t); return list; } /** * 查询 * * @param pd 页面对象 * @param param 传入对象 * @param serviceCode 服务编码 * @param t 返回类 * @param * @return */ public static List getForApis(IPageData pd, T param, String serviceCode, Class t) { String url = URL_API + serviceCode; if (param != null) { url += mapToUrlParam(BeanConvertUtil.beanCovertMap(param)); } RestTemplate restTemplate = ApplicationContextFactory.getBean("restTemplate", RestTemplate.class); ResponseEntity 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 list = JSONObject.parseArray(jsonStr, t); return list; } public static ResponseEntity callCenterService(RestTemplate restTemplate, IPageData pd, String param, String url, HttpMethod httpMethod) { ResponseEntity responseEntity = null; long startTime = DateUtil.getCurrentDate().getTime(); logger.debug(url + "调用api开始:" + (startTime)); HttpHeaders header = new HttpHeaders(); if (pd.getHeaders() != null) { for (String key : pd.getHeaders().keySet() ) { if (CommonConstant.USER_ID.equals(key.toLowerCase())) { continue; } header.add(key, pd.getHeaders().get(key).toString()); } } header.add(CommonConstant.HTTP_APP_ID.toLowerCase(), StringUtil.isEmpty(pd.getAppId()) ? AppDto.WEB_APP_ID : pd.getAppId()); header.add(CommonConstant.HTTP_USER_ID.toLowerCase(), StringUtil.isEmpty(pd.getUserId()) ? CommonConstant.ORDER_DEFAULT_USER_ID : pd.getUserId()); header.add(CommonConstant.USER_ID.toLowerCase(), StringUtil.isEmpty(pd.getUserId()) ? CommonConstant.ORDER_DEFAULT_USER_ID : pd.getUserId()); header.add(CommonConstant.HTTP_TRANSACTION_ID.toLowerCase(), StringUtil.isEmpty(pd.getTransactionId()) ? GenerateCodeFactory.getUUID() : pd.getTransactionId()); header.add(CommonConstant.HTTP_REQ_TIME.toLowerCase(), StringUtil.isEmpty(pd.getRequestTime()) ? DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_DEFAULT) : pd.getRequestTime()); header.add(CommonConstant.HTTP_SIGN.toLowerCase(), ""); HttpEntity httpEntity = new HttpEntity(param, header); //logger.debug("请求中心服务信息,{}", httpEntity); try { responseEntity = restTemplate.exchange(url, httpMethod, httpEntity, String.class); } catch (HttpStatusCodeException e) { //这里spring 框架 在4XX 或 5XX 时抛出 HttpServerErrorException 异常,需要重新封装一下 logger.error("调用中心服务失败", e); responseEntity = new ResponseEntity(e.getResponseBodyAsString(), e.getStatusCode()); } catch (Exception e) { logger.error("调用中心服务失败", e); responseEntity = new ResponseEntity(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR); } finally { logger.debug("请求地址为,{} 请求中心服务信息,{},中心服务返回信息,{}", url, httpEntity, responseEntity); logger.debug(url + "调用api耗时:" + (DateUtil.getCurrentDate().getTime() - startTime)); } return responseEntity; } /** * map 参数转 url get 参数 非空值转为get参数 空值忽略 * * @param info map数据 * @return url get 参数 带? */ public static String mapToUrlParam(Map info) { String urlParam = ""; if (info == null || info.isEmpty()) { return urlParam; } urlParam += "?"; for (Object key : info.keySet()) { if (StringUtil.isNullOrNone(info.get(key))) { continue; } urlParam += (key + "=" + info.get(key) + "&"); } urlParam = urlParam.endsWith("&") ? urlParam.substring(0, urlParam.length() - 1) : urlParam; return urlParam; } }