1.问题描述:
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.cyipp.skynet.common.domain.po.CrawlerPlatform;
local class incompatible: stream classdesc serialVersionUID = -4035754716493701436, local class serialVersionUID = 5484850838710543192
at org.springframework.core.serializer.support.DeserializingConverter.convert(DeserializingConverter.java:78)
at org.springframework.core.serializer.support.DeserializingConverter.convert(DeserializingConverter.java:36)
at org.springframework.data.redis.serializer.JdkSerializationRedisSerializer.deserialize(JdkSerializationRedisSerializer.java:82)
... 72 common frames omitted
2.问题根由:
A:CrawlerPlatform implements Serializable 对象实现了序列化
B:DTO extends CrawlerPlatform
C:给CrawlerPlatform新增(修改或删除)了字段,local class serialVersionUID 默认是会自动变化的
序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
有两种生成方式:
1. 一个是默认的1L,比如:private static final long serialVersionUID = 1L;
2. 一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
private static final long serialVersionUID = xxxxL;
当你一个类实现了Serializable接口,如果没有定义serialVersionUID,系统会根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段。
3.解决方法:
给类 CrawlerPlatform 加上 private static final long serialVersionUID = -4035754716493701436L;