spring json 序列化 long to string
问题:
在使用 spring rest controller 进行 json 序列化时,我希望将 long 值序列化为 String。但是,当在内部服务之间使用 feign 接口时,却遇到了问题,long 值仍然以数字形式序列化。
解决方案:
为了解决此问题,针对 feign 接口和 rest controller 应采用不同的配置策略。
feign 接口:
- 配置 feign 的编码器为 springencoder:
@configuration public class feignconfig { @bean public encoder feignencoder() { return new springencoder(new mappingjackson2httpmessageconverter()); } }
- 设置 jackson 的 objectmapper:
objectmapper objectmapper = new objectmapper(); objectmapper.configure(serializationfeature.write_bigdecimal_as_plain, true); objectmapper.configure(jsongenerator.feature.write_bigdecimal_as_plain, true);
- 将自定义的 objectmapper 注入 feign builder:
Feign.builder() .encoder(feignEncoder()) .objectMapper(objectMapper) ...
rest controller:
由于 rest controller 默认使用容器中的 objectmapper,因此无需额外配置。
通过这些配置,feign 接口将 long 值序列化为 string,而 rest controller 则保留原始数字格式。