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

GitHub 加速计划 / js / json
41.72 K
6.61 K
下载
适用于现代 C++ 的 JSON。
最近提交(Master分支:1 个月前 )
960b763e 4 个月前
8c391e04 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐