这篇文章讨论了后端传递 Long 类型数值到前端时的精度丢失问题,主要原因是前端只能接收最多16位数字。为解决此问题,提出了两种方案:一是自定义消息转换器,将 Long 类型数据转换为 String 类型;二是在实体类属性上使用 @JsonSerialize 注解,确保 Long 类型正确显示。两种方案均有效,适用于不同场景。
前言
最近在写评论插件时,id使用雪花算法生成(Long),结果传递到前端时发现id最后几位精度丢失全变成了0。
后面经过几番排查后发现前端能够接收的数字最多只能是16位,所以会造成精度丢失。
可以看到后端传递的数据是没有任何问题的,但是接收时精度就丢失了。
在考虑到不改变业务结构的情况下,有两种解决方案。
方案一:自定义消息转换器
通过自定义消息转换器,将传递给前端的Long类型数据转换为String类型数据。
这个方法会将所有传到前端的Long类型转为String。
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import java.util.List;
@Configuration
public class DataConfig implements WebMvcConfigurer {
/**
* 将 Long类型数据转为String
* @param converters
*/
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
MappingJackson2HttpMessageConverter mJHttpMessageConverter = new MappingJackson2HttpMessageConverter();
ObjectMapper objectMapper = mJHttpMessageConverter.getObjectMapper();
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
objectMapper.registerModule(simpleModule);
mJHttpMessageConverter.setObjectMapper(objectMapper);
converters.add(0, mJHttpMessageConverter);
}
}
可以看到前端接收的数据已经是正常显示了
方案二:注解
在需要转化的实体类属性加上注解。也可以实现和上面同样的效果。
比如id字段:
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import lombok.Data;
@Data
public class Comment {
@JsonSerialize(using = ToStringSerializer.class)
private Long id;
private String ahzoo;
}
版权声明
本文依据 CC-BY-NC-SA 4.0 许可协议授权,请您在转载时注明文章来源为 Z次元 ,若本文涉及转载第三方内容,请您一同注明。
评论区
发表评论
这里还没有评论哦
快来发一条评论抢占前排吧
前言
方案一:自定义消息转换器
方案二:注解