Hello! 欢迎来到小浪资源网!

Spring Boot下Feign与REST Controller如何分别序列化Long为String?


Spring Boot下Feign与REST Controller如何分别序列化Long为String?

spring json 序列化 long to string

问题:

在使用 spring rest controller 进行 json 序列化时,我希望将 long 值序列化为 String。但是,当在内部服务之间使用 feign 接口时,却遇到了问题,long 值仍然以数字形式序列化。

解决方案:

为了解决此问题,针对 feign 接口和 rest controller 应采用不同的配置策略。

feign 接口:

  1. 配置 feign 的编码器为 springencoder:
@configuration public class feignconfig {      @bean     public encoder feignencoder() {         return new springencoder(new mappingjackson2httpmessageconverter());     } }
  1. 设置 jackson 的 objectmapper:
objectmapper objectmapper = new objectmapper(); objectmapper.configure(serializationfeature.write_bigdecimal_as_plain, true); objectmapper.configure(jsongenerator.feature.write_bigdecimal_as_plain, true);
  1. 将自定义的 objectmapper 注入 feign builder:
Feign.builder()         .encoder(feignEncoder())         .objectMapper(objectMapper)         ...

rest controller:

由于 rest controller 默认使用容器中的 objectmapper,因此无需额外配置。

通过这些配置,feign 接口将 long 值序列化为 string,而 rest controller 则保留原始数字格式。

相关阅读