|  |  |  | 
|---|
|  |  |  | import com.doumee.dao.business.MemberMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.CrmInterfaceLog; | 
|---|
|  |  |  | import com.doumee.dao.business.model.InterfaceLog; | 
|---|
|  |  |  | import com.doumee.dao.web.response.ZSZXCatalogResponse; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.data.redis.core.RedisTemplate; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | 
|---|
|  |  |  | public class ZbomZhongTaiServiceImpl implements ZbomZhongTaiService { | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private InterfaceLogMapper interfaceLogMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RedisTemplate<String, Object> redisTemplate; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取用户登陆token | 
|---|
|  |  |  | * @param param | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.USER_GET_TOKEN_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTUserGetTokenResponse>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取用户登陆token | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ZSZXCatalogResponse getZSZXCatalogs(){ | 
|---|
|  |  |  | ZSZXCatalogResponse response = new ZSZXCatalogResponse(); | 
|---|
|  |  |  | ZTCatalogListRequest param = new ZTCatalogListRequest(); | 
|---|
|  |  |  | param.setCatalogCode(ZTConstants.CatalogCode.ZHISHUO_ZHUANGXIU); | 
|---|
|  |  |  | List<ZTCatalogInfoResponse> cataList = getCatalogList(param); | 
|---|
|  |  |  | if(cataList!=null ){ | 
|---|
|  |  |  | for(ZTCatalogInfoResponse data : cataList){ | 
|---|
|  |  |  | if(StringUtils.equals(data.getCode(), ZTConstants.CatalogCode.JIADE_ID)){ | 
|---|
|  |  |  | response.setJdId(data); | 
|---|
|  |  |  | }else if(StringUtils.equals(data.getCode(), ZTConstants.CatalogCode.CHUFANGSHEJI)){ | 
|---|
|  |  |  | response.setCfsj(data); | 
|---|
|  |  |  | }else if(StringUtils.equals(data.getCode(), ZTConstants.CatalogCode.QW_SHEJI)){ | 
|---|
|  |  |  | response.setQwsj(data); | 
|---|
|  |  |  | }else if(StringUtils.equals(data.getCode(), ZTConstants.CatalogCode.SHOUNASHEJI)){ | 
|---|
|  |  |  | response.setSnsj(data); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return response; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 用户信息同步 | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.USER_UPDATE_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTUserGetTokenResponse>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.USER_LOGOUT_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<Object>>(){}); | 
|---|
|  |  |  | if(result!=null ){ | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public  List<ZTCatalogInfoResponse> getCatalogList(ZTCatalogListRequest param){ | 
|---|
|  |  |  | ZTBaseResponse<List<ZTCatalogInfoResponse>> result = sendHttpRequest( | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ZTBaseResponse<List<ZTCatalogInfoResponse>> result = sendHttpRequest( | 
|---|
|  |  |  | ZTConstants.IntegerUrl.CATALOG_LIST_URL, | 
|---|
|  |  |  | ZTConstants.IntegerName.CATALOG_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<List<ZTCatalogInfoResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取分类和分类下的标签 | 
|---|
|  |  |  | * @param param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public      List<ZTTagInfoResponse> getTagList(ZTCatalogListRequest param){ | 
|---|
|  |  |  | ZTBaseResponse<List<ZTTagInfoResponse>> result = sendHttpRequest( | 
|---|
|  |  |  | ZTConstants.IntegerUrl.TAG_LIST_URL, | 
|---|
|  |  |  | ZTConstants.IntegerName.TAG_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<List<ZTTagInfoResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.CONTENT_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTBasePageResponse<ZTContentListResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.CONTENT_INFO_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTContentInfoResponse>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.COLLECT_DO_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<Object>>(){}); | 
|---|
|  |  |  | if(result!=null ){ | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.LIKE_DO_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<Object>>(){}); | 
|---|
|  |  |  | if(result!=null ){ | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.SHARE_DO_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<Object>>(){}); | 
|---|
|  |  |  | if(result!=null ){ | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.VIEW_DO_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<Object>>(){}); | 
|---|
|  |  |  | if(result!=null ){ | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.COLLECT_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTBasePageResponse<ZTContentListResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.LIKE_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<ZTBasePageResponse<ZTContentListResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ZTConstants.IntegerName.AREA_LIST_NAME, | 
|---|
|  |  |  | param.getToken(), | 
|---|
|  |  |  | param.getUserType(), | 
|---|
|  |  |  | JSONObject.toJSONString(param )); | 
|---|
|  |  |  | JSONObject.toJSONString(param ), | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<List<ZTAreaInfoResponse>>>(){}); | 
|---|
|  |  |  | if(result!=null){ | 
|---|
|  |  |  | return result.getData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public   <T> ZTBaseResponse<T> sendHttpRequest(String url,String name,String token,String userType,String param){ | 
|---|
|  |  |  | public   <T>   ZTBaseResponse<T> sendHttpRequest(String url,String name,String token,String userType,String param,TypeReference<ZTBaseResponse<T>> typeReference){ | 
|---|
|  |  |  | log.info("【"+name+"】================开始===="+ JSONObject.toJSONString(param)); | 
|---|
|  |  |  | String res = null; | 
|---|
|  |  |  | int success = 0; | 
|---|
|  |  |  | 
|---|
|  |  |  | Map<String,String> headers = new HashMap<>(); | 
|---|
|  |  |  | headers.put(ZTConstants.HEADER_TOKEN,token); | 
|---|
|  |  |  | headers.put(ZTConstants.HEADER_USERTYPE,userType); | 
|---|
|  |  |  | res = HttpsUtil.postJsonWithHeaders(url,param,headers); | 
|---|
|  |  |  | TypeReference typeReference = | 
|---|
|  |  |  | new TypeReference<ZTBaseResponse<T>>(){}; | 
|---|
|  |  |  | String index = (String) redisTemplate.opsForValue().get(Constants.RedisKeys.ZBOM_ZHONGTAI_API_URL); | 
|---|
|  |  |  | res = HttpsUtil.postJsonWithHeaders(index+url,param,headers); | 
|---|
|  |  |  | ZTBaseResponse<T>  result = JSONObject.parseObject(res, typeReference.getType()); | 
|---|
|  |  |  | logResult(result,name); | 
|---|
|  |  |  | if(StringUtils.equals(result.getCode(),ZTConstants.CODE_SUCCESS)){ | 
|---|
|  |  |  | if(Constants.equalsInteger(result.getCode(),ZTConstants.CODE_SUCCESS)){ | 
|---|
|  |  |  | return  result; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | success =1; | 
|---|
|  |  |  | 
|---|
|  |  |  | interfaceLogMapper.insert(log); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | private static void logResult(ZTBaseResponse res,String name) { | 
|---|
|  |  |  | if(StringUtils.equals(res.getCode(), ZTConstants.CODE_SUCCESS)){ | 
|---|
|  |  |  | if(Constants.equalsInteger(res.getCode(),ZTConstants.CODE_SUCCESS)){ | 
|---|
|  |  |  | log.info("【中台接口:"+name+"】================成功====\n"+res); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | log.error("【中台接口:"+name+"】================失败====:\n"+ res); | 
|---|