Long类型框架自动序列化成String失效问题排查
问题描述
微服务架构下进行业务模块开发时,发现每次涉及到Long类型的字段时需要自己手动增加@JsonSerialize(using = ToStringSerializer.class)注解来序列化成字符串防止精度丢失。
但是我觉得这样处理不合理,我认为太笨拙,肯定有全局的方式。所以了解原理后尝试通过修改框架源码,通过objectMapper.registerModule(new LongModule())的方式来全局解决这个问题。
修改完成之后本地测试没问题,但是部署到开发服务器就出问题了。
由于JS的Number类型只支持17位长度,后端返回Long类型是20位的,所以最后三位被自动转成0。
猜想
1. 写错了
首先想到的就是哪里写错了,我检查了代码,本地多次测试都是能得到期望值;
2. 重新使用
重新使用@JsonSerialize(using = ToStringSerializer.class)直接对字段进行序列化,部署之后问题得到解决,由此我判断是开发环境框架的jar包有问题导致我修改后的代码没生效;
验证猜想
1.验证猜想
开发环境的jar包是从maven仓库下载的,首先我就去maven下载了最新jar包,用jd-gui反编译工具查看之后发现jar包没问题,这就奇怪了。
2.继续猜想
因为我们开发环境做过一次迁移工作,所有的应用和仓库等等,宿主机IP都更新了,我怀疑当时安装maven的同事没有更新仓库的配置文件,所以去开发服务器上检查了maven的settings.xml配置,结果发现,是最新的配置。。。
3.再次猜想
会不会是打包的时候出问题了,打包过程中下载的jar包版本不对。
4.再次验证
所以我从Jenkins工作目录找到了对应应用的jar包,反编译之后一看,果然代码不对。
5.疑惑
maven是正确的配置,为什么打包的时候会下载错误的jar包呢?
6.找到原因,解决疑惑
maven是会根据settings.xml文件找到正确的仓库,这一步没问题。查看本地仓库中对于jar包的pom文件,发现pom文件是旧版的仓库地址,因为做迁移的时候,nexus应用是最后做的迁移,所以应用迁移完成后发布的时候,pom文件是从旧仓库下载的。为什么新的maven配置文件更新后,没有下载jar包最新的pom文件?因为我们更新框架jar包没有使用版本号,并且使用的是release仓库,maven的默认策略是不会去更新相同版本号的release版本jar包。
7.解决
删除本地仓库中框架jar包的pom文件,重新部署应用,发现自动下载了最新的pom文件,然后去掉@JsonSerialize(using = ToStringSerializer.class)注解上开发环境验证Long类型精度丢失的问题。Long传给前端没有丢失精度,至此问题解决。
End
Long类型框架自动序列化成String失效问题排查的更多相关文章
- java将int类型的变量转化成String类型的
第一种方法:String的valueOf方法,int i=5;String s=String.valueOf(i);第二种方法,直接在int后面加一个空的字符串,因为在java里面,默认任务int类型 ...
- webapi 实体作为参数,自动序列化成xml的问题
原文:http://bbs.csdn.net/topics/392038917 关注 Ray_Yang Ray_Yang 本版等级: #6 得分:0回复于: 2016-10-27 21:30:51 ...
- 基础类型转化成String 转
基础类型转化成String 在程序中你可能时常会需要将别的类型转化成String,有时候可能是一些基础类型的值.在拼接字符串的时候,如果你有两个或者多个基础类型的值需要放到前面,你需要显式的将第一个值 ...
- 利用自动类型转换存储string类型
类型转换是我们最常用的功能.就像上战场用的枪一样,敌人用的冲锋枪, 自己手里就一把步枪,打起仗来始终有点不爽. 因此,基本功能的完善很重要. 通常情况下我们需要String类型转其它的基础类型.这时我 ...
- java对象转化成String类型
在java项目的实际开发和应用中,常常需要用到将对象转为String这一基本功能.本文将对常用的转换方法进行一个总结.常用的方法有Object#toString(),(String)要转换的对象,St ...
- double类型转化成string
public static void main(String[] args) { double priceWithFreight = 1200.5698d; System.out.println(pr ...
- Linq之隐式类型、自动属性、初始化器、匿名类
目录 写在前面 系列文章 隐式类型 自动属性 初始化器 匿名类 总结 写在前面 上篇文章是本系列的小插曲,也是在项目中遇到,觉得有必要总结一下,就顺手写在了博客中,也希望能帮到一些朋友.本文将继续介绍 ...
- C#将对象序列化成JSON字符串
C#将对象序列化成JSON字符串 public string GetJsonString() { List<Product> products = new List<Product& ...
- 将Java对象序列化成JSON和XML格式
1.先定义一个Java对象Person: public class Person { String name; int age; int number; public String getName() ...
随机推荐
- VB Aspose.Pdf 字体变小方格问题处理
宋体是这样写的:SimSun原先以为是:宋体 先定义字体,在PDF中无法设置,这个找了很久,原来是使用:FontRepository.FindFont方式,这个坑了很久,很多都说是setFont,压根 ...
- win10下安装jmeter
http://note.youdao.com/noteshare?id=49a31ed75e139e03055bb6fc79342ac2&sub=EFA14CDD037C4EA4BE2A42B ...
- 笔记-13-多线程 Thread方法 线程安全 生产者和消费者 死锁和阻塞 练习
题目1 编写程序,创建两个线程对象,一根线程循环输出"播放背景音乐",另一根线程循环输出"显示画面";要求: 1: 1个线程使用Runnable接口的匿名内部类 ...
- STS或eclipse中导入新项目出现红色感叹号红色叉叉的问题
maven项目 原因: jar包缺失 没有正确配置Maven仓库 解决: Window->Preferences->Maven->Installations->Add 添加你的 ...
- java基础第一节课随笔
第一题:1.定义一个HelloWold类2.在类中定义主方法3.在主方法中使用输出语句在dos控制台打印HelloWorld 打印结果如:HelloWorld4.在案例中使用当行注释.多行注释添加相关 ...
- 【VBA】日期时间
当前日期: Sub 测试() Debug.Print Date End Sub 当前时间: Sub 测试() Debug.Print Date End Sub 几月: Sub 测试() Debug.P ...
- sentinel (史上最全+入门教程)
文章很长,建议收藏起来,慢慢读! 高并发 发烧友社群:疯狂创客圈 为小伙伴奉上以下珍贵的学习资源: 疯狂创客圈 经典图书 : 极致经典 < Java 高并发 三部曲 > 面试必备 + 大厂 ...
- Luat Inside | 致敬经典,使用Air724UG制作简易贪吃蛇
作者简介: 打盹的消防车--活跃于Luat社群的新生代全能开发者,东北小伙儿爽朗幽默.好学敏思,更是实力行动派.幼年曾手握火红炽铁而后全然无恙,堪称魔幻经历:如今热衷于各类嵌入式软硬件研究,快意物联江 ...
- Pytest学习笔记2-setup和teardown
前言 我们在做自动化的时候,常常有这样的需求: 执行每一条用例时,都重新启动一次浏览器 每一条用例执行结束时,都清除测试数据 在unittest中,我们可以使用 setUp() 和 tearDown( ...
- 题解 P5318 【【深基18.例3】查找文献】
题目传送门 根据本蒟蒻细致粗略的分析 这明显是一道水题模(du)板(liu)题 可我竟然没有一遍AC; 为更好地食用本题解需要了解以下内容 1.dfs(大法师深搜) 2.bfs(冰法师广搜)/dij最 ...