目录
1. spring-data-redis支持的序列化策略
2. 修改spring配置文件
痛点:
spring-data-redis中redisTemplate默认使用JDK的序列化策略,会出现两个问题
解决方案: 使用Jackson serializer替代JDK Serializer;
StringRedisSerializer结合GenericJackson2JsonRedisSerializer
spring-data-redis默认采用的序列化策略有两种,一种是String的序列化策略,一种是JDK的序列化策略。
参考博客 https://blog.csdn.net/pcwblover008/article/details/79915205
redisTemplate可自定义各种key和各种value的序列化方式:
spring-data-redis的序列化类有下面这几个:
博客https://stackoverflow.com/questions/13215024/weird-redis-key-with-spring-data-jedis?answertab=votes#tab-top中,使用了Jackson2JsonRedisSerializer, 需要在配置文件中, 配置一个类,用于反序列化. 这是致命缺陷!!
所以, 我们推荐使用GenericJackson2JsonRedisSerializer
StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。StringRedisSerializer
RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。JdkSerializationRedisSerializer
key和hashKey: 推荐使用 StringRedisSerializer: 简单的字符串序列化
hashValue: 推荐使用 GenericJackson2JsonRedisSerializer:类似Jackson2JsonRedisSerializer,但使用时构造函数不用特定的类
参考博客 https://www.cnblogs.com/grey-wolf/p/7910232.html
策略: defaultSerializer, 设置为GenericJackson2JsonRedisSerializer;
所有的key(key和hashKey), 设置为StringRedisSerializer
SpringDataRedisDemo工程使用的配置文件信息:
1. key为"namehash", filed为"e", 添加value为数组{1,2,3}
2. key为"namehash", filed为"f", 添加value为列表["齐一","牛二"]
3. key为"namehash", filed为"g", 添加value为散列{"1":"胡三","2":"虎四","3":"marin"}
结果是:
注意: 如果要redis-cli显示中文,需要启动redis_cli的时候,在后面加上 --raw