Java 后端给前端返回的long精度缺失,导致数据不一致

在Java等语言中,Serializable接口是用来标识一个类的对象可以被序列化,即可以转换为字节流以便存储或传输。然而,将long类型的数据转换成字符串格式进行序列化并不直接涉及实现Serializable接口。你所提到的序列化是指如何将对象转换为JSON格式(或其他格式),以便通过HTTP响应发送给前端。

对于Java Spring Boot应用来说,通常我们会使用Jackson库来处理JSON序列化和反序列化。为了确保long类型的字段以字符串形式出现在JSON响应中,你可以采取以下几种方法之一:

1. 使用 @JsonSerialize 注解

可以在实体类的特定字段上使用Jackson的@JsonSerialize注解,并指定自定义的序列化器,比如ToStringSerializer,它会把数值转为字符串。

java 复制代码
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;

public class MyEntity {   


    //实体类中加上注解单个处理
    @JsonSerialize(using = ToStringSerializer.class)
    private Long id;

    // getters and setters
}

2. 全局配置

如果你希望所有Long类型的字段都自动转换为字符串,可以通过配置Jackson的ObjectMapper来实现全局设置。这可以在Spring Boot应用的配置类中完成。

java 复制代码
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.fasterxml.jackson.databind.module.SimpleModule;

//使用全局配置,处理所有的long类型
@Configuration
public class JacksonConfig {

    @Bean
    public ObjectMapper objectMapper() {
        SimpleModule module = new SimpleModule();
        module.addSerializer(Long.class, new ToStringSerializer());
        module.addSerializer(Long.TYPE, new ToStringSerializer());

        ObjectMapper mapper = new ObjectMapper();
        mapper.registerModule(module);
        return mapper;
    }
}
相关推荐
咖啡教室3 小时前
java日常开发笔记和开发问题记录
java
咖啡教室3 小时前
java练习项目记录笔记
java
鱼樱前端3 小时前
maven的基础安装和使用--mac/window版本
java·后端
RainbowSea4 小时前
6. RabbitMQ 死信队列的详细操作编写
java·消息队列·rabbitmq
RainbowSea4 小时前
5. RabbitMQ 消息队列中 Exchanges(交换机) 的详细说明
java·消息队列·rabbitmq
李少兄6 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
此木|西贝6 小时前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖6 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
s9123601016 小时前
rust 同时处理多个异步任务
java·数据库·rust
9号达人6 小时前
java9新特性详解与实践
java·后端·面试