springBoot 丢失精度的问题(后台是ok的,前端是丢失的)

在SpringBoot中,从后端向前端传输带有小数的数据时,可能会遇到精度丢失的问题。例如,数值1.00可能被简化为1,造成信息不完整。本文介绍了解决此问题的两种方法:一是将数值作为字符串传递;二是使用自定义的BigDecimalSerialize类,通过@JsonSerialize注解确保数据精度。

情况,springBoot传数据给前端的时候,debug的时候发现数据的精度还是存在的,比如后台传 {money:1.00,price:2.30},传到前台就变成了{money:1,price:2.3},这样是明显的精度的丢失了

解决办法是:1,是用string去传给前端  2,使用注解@JsonSerialize(using=BigDecimalSerialize.class)

 

public class BigDecimalSerialize extends JsonSerializer<BigDecimal>{

@override

public void serialize(BigDecimal value,JsonGenerator gen,SerializerProvider serializerProvider)throws IOException{

if(value !=null && !"".equals(value)){

  gen.writeString(value.setScale(2,BigDecimal.ROUND_HALFDOWN)+"");

}else{

  gen.writeString(value.toString());

}

}

}

Spring Boot解决雪花算法前端精度丢失问题,主要是解决后端Long类型的雪花ID传输到前端后,因JS的Number数据类型精度限制而导致的精度丢失问题,有以下两种主要解决方案: ### 注解方式 在实体类的ID属性上添加`@JsonSerialize`注解,指定使用`ToStringSerializer.class`,这样在使用Jackson进行JSON序列化时,会将Long类型的ID转换为String类型。示例代码如下: ```java import com.baomidou.mybatisplus.annotation.TableId; import com.fasterxml.jackson.databind.annotation.JsonSerialize; import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; import lombok.Data; @Data public class Course { // 序列化时,不采用long类型,而采用string类型,防止雪花精度丢失问题 @JsonSerialize(using = ToStringSerializer.class) @TableId(type = IdType.ASSIGN_ID) // 主键生成策略,雪花 private Long id; private Long companyId; // 公司编号 private String companyName; // 公司名称 } ``` 这种方式适用于对单个实体类的ID属性进行处理,精准控制需要转换的ID字段 [^3][^4]。 ### 配置类实现 适用于全局配置,可在Spring Boot应用中统一将Long类型的ID转换为String类型。虽然引用中未给出具体代码,但思路是配置Jackson的序列化规则,让其在序列化所有Long类型的ID时都转换为String类型。这种方式可以避免在每个实体类的ID属性上都添加注解,提高开发效率 [^1]。 最终方案是前端使用String类型的雪花ID以保持精度,后端及数据库继续使用Long(BigINT)类型,这样既解决了前端精度丢失问题,又不影响数据库查询执行效率。前端将String类型的ID传回服务端时,Spring反序列化参数接收默认支持用Long类型接收 [^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值