parent
8e00b924a9
commit
de097be0e9
@ -0,0 +1,24 @@
|
||||
package com.xjs.common.client;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.xjs.common.aop.ApiLog;
|
||||
import com.xjs.common.client.factory.TianXingWYYFeignFactory;
|
||||
import com.xjs.copywriting.domain.RequestBody;
|
||||
import org.springframework.cloud.openfeign.FeignClient;
|
||||
import org.springframework.cloud.openfeign.SpringQueryMap;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
|
||||
/**
|
||||
* @author xiejs
|
||||
* @desc 天行数据网易云热评接口api调用
|
||||
* @create 2021-12-28
|
||||
*/
|
||||
@FunctionalInterface
|
||||
@FeignClient(name = "tianXingWYY",url = "http://api.tianapi.com/hotreview/index",fallbackFactory = TianXingWYYFeignFactory.class)
|
||||
public interface TianXingWYYFeignClient {
|
||||
@GetMapping
|
||||
@ApiLog(name = "tianXing",
|
||||
url = "http://api.tianapi.com/hotreview/index",
|
||||
method = "Get")
|
||||
JSONObject copyWritingApi(@SpringQueryMap RequestBody requestBody);
|
||||
}
|
@ -1,23 +1,22 @@
|
||||
package com.xjs.common.client.factory;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.xjs.common.client.TianXingFeignClient;
|
||||
import com.xjs.common.client.TianXingPYQFeignClient;
|
||||
import lombok.extern.log4j.Log4j2;
|
||||
import org.springframework.cloud.openfeign.FallbackFactory;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
/**
|
||||
* @author xiejs
|
||||
* @desc 天行数据平台接口降级处理
|
||||
* @desc 天行数据平台朋友圈文案接口降级处理
|
||||
* @create 2021-12-28
|
||||
*/
|
||||
@Log4j2
|
||||
@Component
|
||||
public class TianXingFeignFactory implements FallbackFactory<TianXingFeignClient> {
|
||||
|
||||
public class TianXingPYQFeignFactory implements FallbackFactory<TianXingPYQFeignClient> {
|
||||
@Override
|
||||
public TianXingFeignClient create(Throwable cause) {
|
||||
log.error("英语模块文案服务调用失败:{},执行降级处理", cause.getMessage());
|
||||
public TianXingPYQFeignClient create(Throwable cause) {
|
||||
log.error("英语模块网易云热评服务调用失败:{},执行降级处理", cause.getMessage());
|
||||
return requestBody -> {
|
||||
JSONObject jsonObject = new JSONObject();
|
||||
//构建一个异常json给下层接口处理
|
@ -0,0 +1,27 @@
|
||||
package com.xjs.common.client.factory;
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.xjs.common.client.TianXingWYYFeignClient;
|
||||
import lombok.extern.log4j.Log4j2;
|
||||
import org.springframework.cloud.openfeign.FallbackFactory;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
/**
|
||||
* @author xiejs
|
||||
* @desc 天行数据平台网易云热评接口降级处理
|
||||
* @create 2021-12-28
|
||||
*/
|
||||
@Log4j2
|
||||
@Component
|
||||
public class TianXingWYYFeignFactory implements FallbackFactory<TianXingWYYFeignClient> {
|
||||
@Override
|
||||
public TianXingWYYFeignClient create(Throwable cause) {
|
||||
log.error("英语模块朋友圈文案服务调用失败:{},执行降级处理", cause.getMessage());
|
||||
return requestBody -> {
|
||||
JSONObject jsonObject = new JSONObject();
|
||||
//构建一个异常json给下层接口处理
|
||||
jsonObject.put("error", 500);
|
||||
return jsonObject;
|
||||
};
|
||||
}
|
||||
}
|
@ -0,0 +1,60 @@
|
||||
package com.xjs.copywriting.factory.impl;
|
||||
|
||||
import cn.hutool.http.HttpStatus;
|
||||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.xjs.common.client.TianXingWYYFeignClient;
|
||||
import com.xjs.common.config.TianXingProperties;
|
||||
import com.xjs.common.enums.StatusEnum;
|
||||
import com.xjs.common.exception.ApiException;
|
||||
import com.xjs.copywriting.domain.CopyWriting;
|
||||
import com.xjs.copywriting.domain.RequestBody;
|
||||
import com.xjs.copywriting.factory.CopyWritingFactory;
|
||||
import com.xjs.copywriting.mapper.CopyWritingMapper;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
|
||||
/**
|
||||
* @author xiejs
|
||||
* @desc 天行数据网易云热评平台工厂实现
|
||||
* @create 2021-12-28
|
||||
*/
|
||||
@Service
|
||||
public class TianXingWYYCopyWritingFactory implements CopyWritingFactory {
|
||||
|
||||
@Autowired
|
||||
private TianXingProperties tianXingProperties;
|
||||
@Autowired
|
||||
private TianXingWYYFeignClient tianXingWYYFeignClient;
|
||||
@Resource
|
||||
private CopyWritingMapper copyWritingMapper;
|
||||
|
||||
@Override
|
||||
public CopyWriting productCopyWriting(RequestBody requestBody) {
|
||||
requestBody.setKey(tianXingProperties.getKey());
|
||||
JSONObject jsonObject = tianXingWYYFeignClient.copyWritingApi(requestBody);
|
||||
//调用服务正常
|
||||
if(jsonObject.containsKey("code")){
|
||||
if (HttpStatus.HTTP_OK !=jsonObject.getInteger("code")) {
|
||||
throw new ApiException("天行数据网易云热评接口调用异常");
|
||||
}
|
||||
JSONArray newslist = jsonObject.getJSONArray("newslist");
|
||||
String content = newslist.getJSONObject(0).getString("content");
|
||||
String source = newslist.getJSONObject(0).getString("source");
|
||||
CopyWriting copyWriting = new CopyWriting();
|
||||
copyWriting.setContent(content);
|
||||
copyWriting.setSource(source);
|
||||
copyWriting.setType(StatusEnum.WYY);
|
||||
copyWritingMapper.insert(copyWriting);
|
||||
return copyWriting;
|
||||
}else {
|
||||
//调用服务失败的降级之后的处理
|
||||
if (jsonObject.containsKey("error")) {
|
||||
return copyWritingMapper.getOneToNew();
|
||||
}
|
||||
return new CopyWriting();
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in new issue