Java-修改二进制序列化对象的serialVersionUID

问题描述

作为一种技巧,您可以使用serialver工具生成jvm可能使用的serialVer:

serialver -classpath不论com.foo.bar.MyClass

如果您随后在类中手动设置了serialVerUID,则应该进行匹配,并且应该能够加载,前提是您没有以无效的方式更改类。

解决方法

几个月前,我将java.io.Serializable对象序列化为文件。现在,我需要阅读内容,但是从那以后,serialVersionUID发生了变化,现在我遇到了“类不兼容”错误。我知道一个事实,即没有任何数据成员已更改,因此唯一的障碍是serialVersionUID检查。

有没有办法禁用检查或修改二进制文件中的serialVersionUID?

澄清说明

这个问题是假设我无法编辑源代码。有什么方法可以破解.class文件,也可以破解序列化的目标文件(使用十六进制编辑器,并在某个特定偏移量处更改值)?