@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序列化。有些接口很容易发现问题,但是对于一些有驼峰和_命名的字段接口,而且_的字段如果没有值,还给了默认值,导致调用接口还是成功。等到上线后发现字段值不生效,只能一直返回默认值就尴尬了。

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐