反序列化失败Failed to deserialize --- local class incompatible: stream classdesc serialVersionUID
Failed to --- 失败 Class 序列化 stream local
2023-09-14 08:57:00 时间
反序列化失败:
java.lang.IllegalStateException: Failed to execute CommandLineRunner at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:779) at org.springframework.boot.SpringApplication.callRunners(SpringApplication.java:760) at org.springframework.boot.SpringApplication.afterRefresh(SpringApplication.java:747) at org.springframework.boot.SpringApplication.run(SpringApplication.java:315) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1162) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1151) at com.lk.acApplication.main(acApplication.java:27) Caused by: 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.lk.base.ac.model.Tenant; local class incompatible: stream classdesc serialVersionUID = -6743567631108323096, local class serialVersionUID = -3998150864330771094 at org.springframework.data.redis.serializer.JdkSerializationRedisSerializer.deserialize(JdkSerializationRedisSerializer.java:82) at org.springframework.data.redis.cache.RedisCache$CacheValueAccessor.deserializeIfNecessary(RedisCache.java:477) at org.springframework.data.redis.cache.RedisCache.lookup(RedisCache.java:323) at org.springframework.data.redis.cache.RedisCache.get(RedisCache.java:184) at org.springframework.data.redis.cache.RedisCache.get(RedisCache.java:133) at org.springframework.cache.interceptor.AbstractCacheInvoker.doGet(AbstractCacheInvoker.java:71) at org.springframework.cache.interceptor.CacheAspectSupport.findInCaches(CacheAspectSupport.java:537) at org.springframework.cache.interceptor.CacheAspectSupport.findCachedItem(CacheAspectSupport.java:503) at org.springframework.cache.interceptor.CacheAspectSupport.execute(CacheAspectSupport.java:389) at org.springframework.cache.interceptor.CacheAspectSupport.execute(CacheAspectSupport.java:327) at org.springframework.cache.interceptor.CacheInterceptor.invoke(CacheInterceptor.java:61) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:656) at com.lk.base.ac.dao.TenantDao$$EnhancerBySpringCGLIB$$c5ba8fe5.selectAll(<generated>) at com.lk.CacheCommandLineRunner.run(CacheCommandLineRunner.java:35) at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:776) ... 6 common frames omitted 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.lk.base.ac.model.Tenant; local class incompatible: stream classdesc serialVersionUID = -6743567631108323096, local class serialVersionUID = -3998150864330771094 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:80) ... 21 common frames omitted Caused by: java.io.InvalidClassException: com.lk.base.ac.model.Tenant; local class incompatible: stream classdesc serialVersionUID = -6743567631108323096, local class serialVersionUID = -3998150864330771094 at java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:616)
仔细一想, 是我之前把Tenant 信息放到了redis 中, 然后, 重启了服务, 然后再次获取的时候, 就出现了这样的情况.
可以看到根本原因在于:
local class incompatible: stream classdesc serialVersionUID = -6743567631108323096, local class serialVersionUID = -3998150864330771094
只需要在Tenant class 中增加下面的即可:
private static final long serialVersionUID = -6743567631108323096L;
相关文章
- 移动MM failed to find resource file{mmiap.xml}
- flv.js播放视频时出现Failed to execute ‘appendBuffer’ on ‘SourceBuffer’ 错误
- ORA-19563: header validation failed for file
- VS2015安装 Secondary Installer Setup Failed求解决方案
- Check failed: mdb_status == 0 (2 vs. 0) No such file or directory
- nginx重启 failed (98: Address already in use)
- pycharm 报错Connection to Python debugger failed socket closed
- WSL(Linux子系统) gedit 报错 failed to commit changes to dconf: Failed to execute child process “dbus-launch” (No such file or directory)
- 【17】报错Failed to allocate graph: MYRIAD device is not opened.
- CentOS7 Failed to start LSB: Bring up/down networking.解决方法
- cordova报错:Error: Failed to find ‘ANDROID_HOME‘ environment variable. Try setting setting it manually
- Custom tool error: Failed to generate code for the service reference ××××××. Please check other erro
- Gradle sync failed: Failed to find Build Tools revision 26.0.2的解决办法
- MongoDB报错: Error: couldn't connect to server 127.0.0.1:27017, connection attempt failed: SocketExcep
- Failed to resolve: com.android.support:support-annotations:2
- 成功解决CondaHTTPError: HTTP 000 CONNECTION FAILED for url <https://mirrors.tuna.tsinghua.edu.cn/anacond
- 成功解决Exception "unhandled ImportError" DLL load failed: 找不到指定的程序。 libimp.py, Line: 343
- Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources和如何修改idea的默认编码
- kafka.common.KafkaException: Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.
- libcore.io.GaiException: getaddrinfo failed: EAI_NODATA (No address associated with hostname)
- Linux:Libreswan: can‘t offload to because SIOCETHTOOL ETHTOOL_GSSET_INFO failed. Errno 95
- Win10解决Android Studio:Gradle sync failed: Failed to open zip file.
- [Git & GitHub] 解决办法:error: failed to push some refs to 'https://github.com/xxxx.git'