由Java反序列化对象异常想到的

今天写代码时候遇到一个异常,异常信息如下:


Caused by: java.lang.RuntimeException: java.util.concurrent.ExecutionException: org.springframework.data.redis.serializer.SerializationException: Cannot deserialize; nested exception is org.springframework.core.serializer.support.SerializationFailedException: Failed to deserialize payload. Is the byte array a result of corresponding serialization for DefaultDeserializer?; nested exception is java.io.InvalidClassException: com.netease.kaola.generic.act.dto.module.ModuleGoodsDTO; local class incompatible: stream classdesc serialVersionUID = -526324944915280489, local class serialVersionUID = 4094977077022888368


Caused by: org.springframework.core.serializer.support.SerializationFailedException: Failed to deserialize payload. Is the byte array a result of corresponding serialization for DefaultDeserializer?; nested exception is java.io.InvalidClassException: com.netease.kaola.generic.act.dto.module.ModuleGoodsDTO; local class incompatible: stream classdesc serialVersionUID = -526324944915280489, local class serialVersionUID = 4094977077022888368


Cannot deserialize,很明显,反序列化异常。特别注意这一句:redis.serializer.SerializationException: Cannot deserialize,用了Redis存储对象列表,取对象列表时候反序列化出错了。在代码里有这一行 Map<Long, List<ModuleGoods>> moduleIdGoodsListMap = (Map<Long, List<ModuleGoods>>) redisClient.get(RedisKeyConstant.GOODS_INFO_LIST+currentModuleInfo.getId()); 这里stream classdesc serialVersionUID = -526324944915280489,local class serialVersionUID = 4094977077022888368,两个serialVersionUID不一致,反序列化异常。


回想了一下,我给ModuleGoods类新增加了1个字段categoryId,但是ModuleGoods类前面加了 @SuppressWarnings("serial"),没有注明 serialVersionUID,这样新增(修改或删除)了字段,local class serialVersionUID 默认是会自动变化的。


才想起来serialVersionUID的作用:


序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
有两种生成方式:
       一个是默认的1L,比如:private static final long serialVersionUID = 1L;
       一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
       private static final   long     serialVersionUID = xxxxL;


当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供黄色警告,如果没有考虑到兼容性问题时,不管或者简单的加一个 @SuppressWarnings("serial") 注解,就会出现上述问题。


如果你的类Serialized序列化存到硬盘上面后,可是后来你却更改了类的field(增加或减少或改名),当你Deserialize时,就会出现Exception的,这样就会造成不兼容性的问题。
但当serialVersionUID设置相同时,它就会将不一样的field以type的预设值(属性默认值)Deserialize,可避开不兼容性问题。


这里给类 ModuleGoodsDTO 加上 private static final long serialVersionUID = -526324944915280489L; 就好了。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值