这篇文章主要介绍"redis反序列化报错如何解决",在日常操作中,相信很多人在redis反序列化报错如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"redis反序列化报错如何解决"的疑惑有所帮助!此时此刻呢,请跟着小编一起来学习吧!
问题:Cannot deserialize,无法反序列化
分析:
①.、实体类实现了序列化接口后,没有指定序列化id.
可能存到redis的时候是两个属性,但是我们本地业务扩展,新增了一些字段,也是无法完成反序列的.这个时候需要及时清理掉缓存库.
解决方案:
指定序列化id
统一jar包版本
清除redis库
在setValue的序列化方式的时候报错,原来是用的RedisSerializer.json()方法,但是报错,
template.setConnectionFactory(factory); ??//?key序列化方式 ??template.setKeySerializer(RedisSerializer.string()); ??//?value序列化方式 ??template.setValueSerializer(RedisSerializer.json()); ??//?hash?key的序列化方式 ??template.setHashKeySerializer(RedisSerializer.string()); ??//?hash?value的序列化方式 ??template.setHashValueSerializer(RedisSerializer.json());
改成如下即可解决:
template.setConnectionFactory(factory); ??//?key序列化方式 ??template.setKeySerializer(RedisSerializer.string()); ??//?value序列化方式 ??template.setValueSerializer(new?Jackson2JsonRedisSerializer<>(Object.class)); ??//?hash?key的序列化方式 ??template.setHashKeySerializer(RedisSerializer.string()); ??//?hash?value的序列化方式 ??template.setHashValueSerializer(new?Jackson2JsonRedisSerializer<>(Object.class));
它们的区别如下:
但是,它可能会在序列化过程中忽略一些Java对象中的字段,所以呢需要进行一些配置才能完全控制序列化过程.
RedisSerializer.json()使用Redis的内置JSON序列化器,将Java对象序列化为JSON格式的字符串,并将其存储到Redis中.它也可以将从Redis中读取的JSON字符串反序列化为Java对象.
而如果处理的数据较为简单,或者只需要简单地将Java对象转换为JSON格式的字符串进行存储,那么RedisSerializer.json()可能更适合.
到此,关于"redis反序列化报错如何解决"的学习就结束了,希望能够解决大家的疑惑.理论与实践的搭配能更好的让粉丝们变的更强学习,快去试试吧!若想继续学习更多相关知识,请继续关注***网站,小编会继续努力为大家带来更多实用的文章!
以上就是土嘎嘎小编为大家整理的redis反序列化报错如何解决相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!