feign.FeignException$BadRequest: status 400 reading 诡异错误记录
创始人
2024-05-10 01:17:08
0

诡异事情描述:A客户端通过feign调用 服务端接口报错feign.FeignException$BadRequest: status 400 reading。B客户端通过feign调用服务端接口 又是正常的返回。 A和B 项目中导入的相关feign版本都一样。

代码调整前如下:

客户端代码:

@Data
public class ControlRequestDto implements Serializable {private static final long serialVersionUID = -5082851597684307746L;//设备点位名对应的水务集团的编码private String mappingId;//设备点位名private String tag;//控制命令下发时间private Date controlTime;//控制命令值private String controlValue;
}
/*** @author wangtingsong* @date 2022/5/9 16:15* @description 这里的注解FeignClient中的name属性值必须是 你调用的接口模块的spring.application.name 的值*/
@FeignClient(name = "controlcenter")
public interface ControlCenterClient {@PostMapping("/controlcenter/control/controlDevice")String controlDevice(@RequestBody ControlRequestDto controlRequestDto);}

服务端代码:

@RestController
@RequestMapping("/control")
@Slf4j
public class ControlCenterController {@Autowiredprivate ControlCenterService controlCenterService;@PostMapping("/controlDevice")public BaseResult controlDevice(@RequestBody ControlRequestDto dto){log.info("控制设备入参:{}", JSONObject.toJSONString(dto));try {return controlCenterService.controlDevice(dto);}catch (Exception e){log.error("控制设备异常:{}", dto.getTag(),e);return BaseResult.builder().message("控制设备异常").code("500").build();}}
}

问题查找:根据A和B断点来一步步看,最终是哪里调用不一样。发现一个是A调用的是RetryableFeignLoadBalancer中的execute方法 而B调用的是FeignLoadBalancer 中的execute方法。

最后发现参数中的时间controlTime字段在两个方法中显示有点不一样,然后就想到估计是两个类中对 参数的时间类型处理有点不同。(这里到底为什么同样的客户端调用 服务端代码 会走两个不同的LoadBalancer,还在继续研究中)。

解决办法:最终解决是给时间字段加上 @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")

//控制命令下发时间

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")

private Date controlTime;

总结:这种400错误有时候需要注意字段的类型

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...