十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
前言
十载的延川网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都营销网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整延川建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“延川网站设计”,“延川网站推广”以来,每个客户项目都认真落实执行。
在使用feign进行远程方法调用时,如果远程服务端方法出现异常,客户端有时需要捕获,并且把异常信息返回给前端,而如果在开启熔断之后,这个异常会被消化,所以说,如果希望拿到服务端异常,feign.hystrix.enable需要设置为false,而当不开熔断时,我们也有几种方法把拿到服务端的异常信息,下面总结一下。
try...catch方法
这个方法比较直观,也最好理解,但业务层会有很多try...catch这种代码,所以不是很推荐。
注意:虽然服务端方法返回为ResponseEntity,但出现4xx,5xx这些异常时,还是会抛出一个FeignException的异常,而这对于服务来说,向前端抛出的还是5xx的服务端异常,这不是我们希望看到的。
try { ResponseEntity<?> body = productClient.add(name); if (body.getStatusCode().equals(HttpStatus.OK)) { return "test"; } else { return body.getBody().toString(); } } catch (FeignException ex) { return ex.getMessage(); }
feign异常拦截器
我们比较推荐使用这个方法,注册一个bean对象,当feign调用出现异常时,会触发这个方法,然后我们再统一处理这个异常,向下流继续抛出加工后的错误信息。
/** * feign异常拦截器,当从feign抛出异常时走这个对象. */ @Configuration @Slf4j public class FeignClientErrorDecoder implements ErrorDecoder { @Override public Exception decode(String methodKey, Response response) { logger.info("feign client response:", response); String body = null; try { body = Util.toString(response.body().asReader()); } catch (IOException e) { logger.error("feign.IOException", e); } if (response.status() >= 400 && response.status() <= 500) { throw Exceptions.badRequestParams(body); } return errorStatus(methodKey, response); } }
注意,使用这个方式,需要在熔断器关闭时才起作用,因为它们的执行过程是,先走这个拦截器,再走熔断的fallback,所以这个异常会被熔断吞掉,返回状态为200,返回值为你的fallback的默认值。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对创新互联的支持。