@JSONField(name = "env_version")
private String envVersion;
问题:
openfeign请求接口一直获取的是线上的小程序码,无法获取到develop环境的小程序码
排查:
1、打开openfeign debug日志
#level后面是自己feign接口的包名,另外还需要添加feign的日志配置类
logging.level.com.lf.feign: debug
#feign的日志配置类
@Configuration
public class OpenFeignConfiguration {
@Bean
public Logger.Level level() {
return Logger.Level.FULL;
}
}
2、查看openfeign请求日志
发现用JSONField标记字段发现没有转成对应的env_version,导致openfeign请求结果一直响应的是默认值
3、分析问题
JSONField是alibaba fastjson包中的注解,而openfeign底层使用的是jackson,导致不能识别JSONField注解。改成jackson 的JsonProperty的注解即可
@JsonProperty("env_version")
private String envVersion;
总结:
对于json注解的使用,要相互对号,用哪个json的注解,就要用对应的json序列化。有些接口很容易发现问题,但是对于一些有驼峰和_命名的字段接口,而且_的字段如果没有值,还给了默认值,导致调用接口还是成功。等到上线后发现字段值不生效,只能一直返回默认值就尴尬了。