前端解决反序列化long类型精度丢失的问题

场景:vite+VUE3.0

安装插件
yarn add json-bigint
//或
npm install json-bigint
引入插件
import JSONBIG from "json-bigint";
使用片段(自行理解)
  const json = JSONBIG({
    storeAsString: true
  })
  if (item.messageContent !== '') {
    obj = json.parse(item.messageContent)
  }

深入剖析

当我们使用MyBatis-Plus 使用 ID_WORKER 或者 ASSIGN_ID(雪花算法) 生成的id作为主键时,因为其长度,为19位,而前端一般能处理16位,如果不处理的话在前端会造成精度丢失,最后两位会变成00,感觉像是四舍五入后的效果。

如上、当我们使用JSON.parse去处理超过16位的数字时、就会丢失精度

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,可以使用Jackson库来进行JSON的序列化和反序列化,如果要反序列化JSON中的long值,可以根据JSONlong值的格式选择不同的反序列化方式。 如果JSON中的long值是一个数字,可以直接使用long类型的属性进行反序列化,例如: ```java public class MyObject { private long id; public long getId() { return id; } public void setId(long id) { this.id = id; } } ``` 使用Jackson进行反序列化时,可以使用以下代码: ```java ObjectMapper mapper = new ObjectMapper(); MyObject obj = mapper.readValue(jsonString, MyObject.class); ``` 如果JSON中的long值是一个字符串,可以使用@JsonDeserialize注解,并指定一个自定义的反序列化器,例如: ```java public class MyObject { @JsonDeserialize(using = StringToLongDeserializer.class) private long id; public long getId() { return id; } public void setId(long id) { this.id = id; } } public class StringToLongDeserializer extends JsonDeserializer<Long> { @Override public Long deserialize(JsonParser parser, DeserializationContext context) throws IOException { String value = parser.getValueAsString(); return Long.parseLong(value); } } ``` 这样,当反序列化JSON字符串时,如果遇到id属性是一个字符串类型,就会使用自定义的反序列化器将其转换为long类型。使用Jackson进行反序列化时,可以使用以下代码: ```java ObjectMapper mapper = new ObjectMapper(); MyObject obj = mapper.readValue(jsonString, MyObject.class); ``` 注意,在使用Jackson进行反序列化时,需要保证JSON字符串中的属性名称与Java对象中的属性名称一致,否则需要使用@JsonAlias注解对属性进行别名映射。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值