错误信息:
feign.FeignException$InternalServerError: status 500 reading CartFeignService#getSelectedCartItems()
at feign.FeignException.errorStatus(FeignException.java:114) ~[feign-core-10.2.3.jar:na]
at feign.FeignException.errorStatus(FeignException.java:86) ~[feign-core-10.2.3.jar:na]
at feign.codec.ErrorDecoder$Default.decode(ErrorDecoder.java:93) ~[feign-core-10.2.3.jar:na]
at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:149) ~[feign-core-10.2.3.jar:na]
at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:78) ~[feign-core-10.2.3.jar:na]
at feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:103) ~[feign-core-10.2.3.jar:na]
at com.sun.proxy.$Proxy101.getSelectedCartItems(Unknown Source) ~[na:na]
at com.atguigu.gulimall.order.service.impl.OrderServiceImpl.lambda$confirmOrder$1(OrderServiceImpl.java:80) ~[classes/:na]
at java.util.concurrent.CompletableFuture$AsyncRun.run$$$capture(CompletableFuture.java:1626) ~[na:1.8.0_101]
at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) ~[na:1.8.0_101]
at java.lang.Thread.run(Thread.java:745) [na:1.8.0_101]
解释:
feign.codec.ErrorDecoder$Default.decode
代表错误编码
,所以Feign在远处调用的时候不能正确接收从被调用方传过来的数据,因此你要思考被调用项目、被调用项目中被调用的项目是否有诡异的数据返回类型,比如BigDecimal
我本次出错误的原因:假设报错项目是A,它使用Feign远程调用了B项目,然后B项目中远程调用了C项目,正是C项目中的被调用方法返回的是BigDecimal
类型的,B项目接收该类型也使用的BigDecimal
类型,这就造成了该问题
解决:
Feign接口中是否有诡异的返回值类型,比如BigDecimal
,你可以换一个类型