全局处理Long类型字段返回前端精度丢失

项目场景:

后端返回一个列表数据到前端,其中有部分字段类型后端定义的是Long类型并且是用雪花算法生成的,从响应数据中发现返回的值与数据库的不一致,丢失了精度


问题描述

后端使用MybatisPlus时,主键字段的主键策略用是@TableId(type = IdType.ASSIGN_ID),意味着主键会生成一个长度为19位的值,后端用Long类型接收没问题,而前端number能接收的最大长度为16位,最大值(9007 1992 5474 0992),此时后端雪花ID返回到前端就出现了丢失精度的情况。
如下图所示:

/**任务主键*/
@ApiModelProperty(value = "任务主键")
@TableId(type = IdType.ASSIGN_ID)
private Long taskId;

丢失精度后


解决方案:

有两种最常见的解决办法:
第一种是局部针对某个字段处理,这种是极其不推荐的,到处都得加;
第二种是全局配置,处理Long类型字段,推荐第二种

1、在字段上加注解 @JsonFormat(shape = JsonFormat.Shape.STRING)

/**任务主键*/
@ApiModelProperty(value = "任务主键")
@JsonFormat(shape = JsonFormat.Shape.STRING)
private Long taskId;

2、增加全局配置类,实现WebMvcConfigurer接口,重写configureMessageConverters方法

@Configuration
public class WebMvcConfiguration implements WebMvcConfigurer {

	/**
     * 添加Long转json精度丢失的配置
     * @Return: void
     */
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
        ObjectMapper objectMapper = new ObjectMapper();
        SimpleModule simpleModule = new SimpleModule();
        simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
        simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
        objectMapper.registerModule(simpleModule);
        jackson2HttpMessageConverter.setObjectMapper(objectMapper);
        converters.add(jackson2HttpMessageConverter);
    }
}

测试:

![](https://img-blog.csdnimg.cn/b946298690c94205af683f4d95c81d40.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值