本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

SpringBoot下Feign与RESTController如何分别序列化Long为String?

网络教程 app 1℃

SpringBoot下Feign与RESTController如何分别序列化Long为String

spring json 序列化 long to string

问题:

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

解决方案:

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

feign 接口:

    配置 feign 的编码器为 springencoder:

@configurationpublic 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 则保留原始数字格式。

以上就是Spring Boot下Feign与REST Controller如何分别序列化Long为String?的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » SpringBoot下Feign与RESTController如何分别序列化Long为String?

喜欢 (0)