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

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

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

这是由于前端 JS 的精度范围有限,我们后端返回的 ID 范围过大,导致前端精度丢失,会影响前端页面获取到的数据结果。

为了解决这个问题,可以在后端 config 包下新建一个全局 JSON 的配置,将整个后端 Spring MVC 接口返回的值的长整型数字转换为字符串进行返回,从而集中解决问题。

java 复制代码
package com.rainbowsea.yupicturebackend.config;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import org.springframework.boot.jackson.JsonComponent;
import org.springframework.context.annotation.Bean;
import org.springframework.http.converter.json.Jackson2ObjectMapperBuilder;

/**
 * Spring MVC Json 配置
 */
@JsonComponent
public class JsonConfig {

    /**
     * 添加 Long 转 json 精度丢失的配置
     */
    @Bean
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        SimpleModule module = new SimpleModule();
        module.addSerializer(Long.class, ToStringSerializer.instance);
        module.addSerializer(Long.TYPE, ToStringSerializer.instance);
        objectMapper.registerModule(module);
        return objectMapper;
    }
}

重启项目进行测试,这次看到的 id 值就正常了:

最后:

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

相关推荐
小二·9 分钟前
Spring Boot 3 + Vue 3 全栈开发实战
vue.js·spring boot·后端
devilnumber14 分钟前
静态代理 & 动态代理:实战运用 + 场景区别 + 怎么选
java·开发语言·代理模式
码农飞哥18 分钟前
Spring Boot 多角色权限隔离实战:接口层+路由层+UI层三层防御,杜绝生产数据泄露
spring boot·状态模式·架构设计·系统设计·权限控制
Upsy-Daisy21 分钟前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
SuperArc199923 分钟前
SpringBoot+Slf4j+Log4j2+mybatis 日志整合
spring boot·mybatis·log4j2·slf4j·日志整合
仿生joe会梦见漫天的大雪吗29 分钟前
CTF学习笔记03:密码口令 —— 从弱口令到字典爆破
后端
自进化Agent智能体31 分钟前
从零到一玩转Hermes Agent:VPS部署 × 模型配置 × 记忆架构 × 多Agent协作
后端
用户46825574591332 分钟前
Testcontainers 在 Windows Docker Desktop 上跑不通:协议层不兼容 + 4 种可行环境
java·后端
Tenaryo36 分钟前
「底层系统基石 · 缓存篇」V —— 写策略、Store Buffer 与内存屏障
后端·面试