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错误有时候需要注意字段的类型

相关内容

热门资讯

精艺传薪,桃李争辉   在“文明交院 匠心育人”党建品牌的战略引领下,山东交通技师学院淬炼出一支精研技术、直面挑战、敢开...
哈马斯就停火提案提交积极回应 ... 转自:央视新闻总台记者获悉,当地时间4日晚间,消息人士表示,巴勒斯坦伊斯兰抵抗运动(哈马斯)已经向相...
招桃花的手链戴左手还是右手 招桃花的手链戴左手还是右手男左女右,建议戴在食指,会引起人们的好奇心,增加桃花数量.呵呵
要练惊人技须下苦功夫的意思 要练惊人技须下苦功夫的意思要练惊人技须下苦功夫的意思要想有高超的技艺,只有下苦功好好练才能行。
金健米业资产置换引问询 主业... 中经记者 蒋政 李正豪 北京报道在收到年报问询函一个月后,“粮食第一股”金健米业(600127.SH...
兔子死前征兆 兔子死前征兆闷闷不乐,有气无力,眼睛半闭着的。有点抽搐
伊春“党群伊家”行动架起党群“... 转自:黑龙江日报 □本报记者 贾红路 对全市109个社区办公场所展开集中升级改造,腾退...
营收连续下滑 “集成灶第一... 转自:中国经营网中经记者 方超 石英婧 上海报道有“集成灶第一股”之称的浙江美大实业股份有限公司(以...
动作喧嚣 主题苍白   □胡婷  《侏罗纪世界:重生》上映,回望系列经典,《侏罗纪公园》开创了雾中巨影的惊悚美学,《失落...
求一部小说,男主角修炼的是混沌... 求一部小说,男主角修炼的是混沌之气,他喜爱的女人是魔界的,修炼的是假混沌之气火属性 空属性 无属性 ...