找回密码
 立即注册
首页 业界区 业界 问题:后端由于字符内容过长,前端展示精度丢失修复 ...

问题:后端由于字符内容过长,前端展示精度丢失修复

蚣澡 2025-9-26 10:35:21
问题:后端由于字符内容过长,前端展示精度丢失修复

虽然我们在 Swagger 接口测试中并没有看到精度丢失的错误,但是在测试‏中,如果你打开 F12‎ 控制台,利用预览来查 看响应数据,就会发现另⁡一个问题:id 的最后 两位好像都变成 0 了!
1.png

这是由于前端 JS 的精度范围有限,我们后端返回的 ID 范围过大,导致前端精度丢失,会影响前端页面获取到的数据结果。
为了解决这个问题,可以在后端 config 包下新建一个全局 JSON 的配置,将整个后端 Spring MVC 接口返回的值的长整型数字转换为字符串进行返回,从而集中解决问题。
2.png
  1. package com.rainbowsea.yupicturebackend.config;
  2. import com.fasterxml.jackson.databind.ObjectMapper;
  3. import com.fasterxml.jackson.databind.module.SimpleModule;
  4. import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
  5. import org.springframework.boot.jackson.JsonComponent;
  6. import org.springframework.context.annotation.Bean;
  7. import org.springframework.http.converter.json.Jackson2ObjectMapperBuilder;
  8. /**
  9. * Spring MVC Json 配置
  10. */
  11. @JsonComponent
  12. public class JsonConfig {
  13.     /**
  14.      * 添加 Long 转 json 精度丢失的配置
  15.      */
  16.     @Bean
  17.     public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
  18.         ObjectMapper objectMapper = builder.createXmlMapper(false).build();
  19.         SimpleModule module = new SimpleModule();
  20.         module.addSerializer(Long.class, ToStringSerializer.instance);
  21.         module.addSerializer(Long.TYPE, ToStringSerializer.instance);
  22.         objectMapper.registerModule(module);
  23.         return objectMapper;
  24.     }
  25. }
复制代码
重启项目进行测试,这次看到的 id 值就正常了:
3.png

最后:

“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。”
4.gif


来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册