如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN

问题

我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误

java 复制代码
java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 9031463779199124957, local class serialVersionUID = -3889253203225845868

我很确定我的库仍然与外部系统兼容,所以我尝试使用 javassist 修改本地 com.essbase.api.base.EssException 的 serialVersionUID

java 复制代码
CtClass cc = pool.get("com.essbase.api.base.EssException");
cc.defrost();
CtField serialField=new CtField(CtClass.longType, "serialVersionUID",cc);
serialField.setModifiers(Modifier.PRIVATE);
serialField.setModifiers(Modifier.STATIC);
serialField.setModifiers(Modifier.FINAL);        
cc.addField(serialField, CtField.Initializer.constant(9031463779199124957l));

错误仍然存​​在,但它说我的本地 serialVersionUID 现在是 -7214799155395914399,所以这是在做一些事情。

有任何关于如何将我的 serialVersionUID 转变为 9031463779199124957l 的想法吗?

解决方案

我最终使它工作,将注入字段的修饰符更改为:

java 复制代码
serialField.setModifiers(Modifier.STATIC | Modifier.FINAL);

这是有效的代码,并且与服务器的通信现已恢复:

java 复制代码
ClassPool pool = ClassPool.getDefault();
pool.insertClassPath(new ClassClassPath(MainTest.class));
CtClass cc = pool.get("com.essbase.api.base.EssException");
cc.defrost();
CtField serialField=new CtField(CtClass.longType, "serialVersionUID",cc);
serialField.setModifiers(Modifier.STATIC | Modifier.FINAL);
cc.addField(serialField, CtField.Initializer.constant(9031463779199124957l));
Class clazz=cc.toClass();
相关推荐
桦说编程1 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen1 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研1 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员2 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋2 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国3 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~3 小时前
《设计模式》装饰模式
java·设计模式
A尘埃3 小时前
企业级Java项目和大模型结合场景(智能客服系统:电商、金融、政务、企业)
java·金融·政务·智能客服系统
Jerry说前后端3 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
喂完待续3 小时前
Apache Hudi:数据湖的实时革命
大数据·数据仓库·分布式·架构·apache·数据库架构