【问题解决】Redis存储Hash-Map<String,Object>时无法序列化问题
来源:互联网 发布:广州网络推广公司 编辑:程序博客网 时间:2024/04/28 07:51
转载请注明出处:http://blog.csdn.net/qq_26525215
本文源自【大学之旅_谙忆的博客】
今天在使用Redis的Map存储Bean时,出现了一个问题。
问题如下:
java.lang.ClassCastException: com.uifuture.TestBean cannot be cast to java.lang.String at org.springframework.data.redis.serializer.StringRedisSerializer.serialize(StringRedisSerializer.java:32) at org.springframework.data.redis.core.AbstractOperations.rawHashValue(AbstractOperations.java:168) at org.springframework.data.redis.core.DefaultHashOperations.put(DefaultHashOperations.java:168) at org.springframework.data.redis.core.DefaultBoundHashOperations.put(DefaultBoundHashOperations.java:90) at com.uifuture.utils.RedisUtil.addMap(RedisUtil.java:299) at com.uifuture.utils.redis.SaveMapCallable.call(SaveMapCallable.java:33) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) at java.util.concurrent.FutureTask.run(FutureTask.java:166) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) at java.lang.Thread.run(Thread.java:722)
我项目使用的是 spring-data-redis管理Redis与序列化。
所以当时我在Spring配置文件中配置的时候,配置了
keySerializer :对于普通K-V操作时,key采取的序列化策略
valueSerializer:value采取的序列化策略
这2种序列化策略。
其实我是少配置了另外2个序列化策略。
造成的后果就是,存储普通的Bean时,是不会出现问题的,也就导致了我从项目开始到现在过去了10多天,才遇到这个问题。
其实解决办法很简单,我少配置了
hashKeySerializer: 在hash数据结构中,hash-key的序列化策略
hashValueSerializer:hash-value的序列化策略
这两个序列化策略。
当时我Spring的配置序列化的策略是:
<!-- 如果不配置Serializer,那么存储的时候只能使用String,如果用对象类型存储,那么会提示错误 can't cast to String!!!--> <property name="keySerializer"> <!--对key的默认序列化器。默认值是StringSerializer--> <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/> </property> <!--是对value的默认序列化器,默认值是取自DefaultSerializer的JdkSerializationRedisSerializer。--> <property name="valueSerializer"> <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/> </property>
需要再增加两种,也就是改成:
<!-- 如果不配置Serializer,那么存储的时候只能使用String,如果用对象类型存储,那么会提示错误 can't cast to String!!!--> <property name="keySerializer"> <!--对key的默认序列化器。默认值是StringSerializer--> <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/> </property> <!--是对value的默认序列化器,默认值是取自DefaultSerializer的JdkSerializationRedisSerializer。--> <property name="valueSerializer"> <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/> </property> <!--存储Map时key需要的序列化配置--> <property name="hashKeySerializer"> <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/> </property> <!--存储Map时value需要的序列化配置--> <property name="hashValueSerializer"> <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/> </property>
这样就可以解决无法序列化Map的问题!
也就是,大家记得写序列化策略的时候,记得一次把这四种都写上。
我查这个错误的时候,硬是看了很多篇博客才发现我少写了。
搞得我都差点要直接自己搞个序列化和反序列化的工具类了。
其他的一些Redis的基础知识,工具类啊,就不写出来了。毕竟只是一篇解决问题的博客、
本文章由[谙忆]编写, 所有权利保留。
欢迎转载,分享是进步的源泉。
转载请注明出处:http://blog.csdn.net/qq_26525215
本文源自【大学之旅_谙忆的博客】
6 0
- 【问题解决】Redis存储Hash-Map<String,Object>时无法序列化问题
- Redis存储List<Map<String, Object>>
- Redis Hash序列化存储问题及解决
- redis的API对String、object、List、Map、Hash常用操作
- redis之Hash存储与String存储内存消耗对比
- redis之Hash存储与String存储内存消耗对比
- 将Map<String,Object> 转String存储数据库
- Map.values()/entrySet()/keySet() 无法序列化问题
- Gson序列化与反序列化成员变量为Map<String,Object>的类对象
- 服务端返回List<Map<String,Object>>数据,$http 无法接收
- List<Map<String, Object>>
- List<Map<String, Object>>
- Map<String, Object> 作用
- List<Map<String, Object>>
- Gson 反序列化Map<String, Object>类型的小问题
- 获取List<Map<String,Object>> list中的值得问题
- Freemarker遍历map<String,Map<String,Object>>
- Map<String,String> map = new Hash<String,String>
- 设计模式(二十一) 状态模式
- POJ2155【二维树状数组模板】
- 2016"百度之星"
- N皇后
- KMP模板+习题
- 【问题解决】Redis存储Hash-Map<String,Object>时无法序列化问题
- ZOJ 3768 Continuous Login
- js动态计算rem
- 可能的克服拖延症的方法
- HDU3787 A+B
- 钉钉机器人
- Bebug和release区别
- 潜变量模型
- oracle中游标详细用法