解决RedisTemplate存储至缓存数据出现乱码的情况

RedisTemplate是Spring对于Redis的封装。


RedisTemplate中定义了对5种数据结构操作。

1
2
3
4
5
6
7
redisTemplate.opsForList();//操作list
redisTemplate.opsForValue();//操作字符串
redisTemplate.opsForCluster();//集群时使用
redisTemplate.opsForGeo();//地理位置时使用
redisTemplate.opsForHash();//操作hash
redisTemplate.opsForSet();//操作set
redisTemplate.opsForZSet();//操作有序set

与StringRedisTemplate的区别

StringRedisTemplate继承RedisTemplate

它们采用的序列化策略不同:

* StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。

* RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。

RedisTemplateStringRedisTemplate它们存取的数据是相互独立的。

解决办法

上文已经提及,在动手的过程中,采用的是RedisTemplate,在传递String类型的数据结构后,查看缓存会发现数据乱码现象。这时候需要修改RedisTemplate的序列化策略。

1
2
3
4
5
RedisSerializer<String> stringSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringSerializer);
redisTemplate.setValueSerializer(stringSerializer);
redisTemplate.setHashKeySerializer(stringSerializer);
redisTemplate.setHashValueSerializer(stringSerializer);

但是注意一点,由于采用了String的序列化策略,所以只接受value值类型为String的参数。

如果传递了Integer类型的参数,直接使用toString()方法存入缓存。

1
ops.set("stock", redPacket.getStock().toString(),TIME_OUT, TimeUnit.SECONDS);

这样就解决了乱码问题。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
@Configuration
public class RedisConfigurtion {
@Autowired
private RedisTemplate redisTemplate;
@Bean
public RedisTemplate<String, Object> stringSerializerRedisTemplate() {
RedisSerializer<String> stringSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringSerializer);
redisTemplate.setValueSerializer(stringSerializer);
redisTemplate.setHashKeySerializer(stringSerializer);
redisTemplate.setHashValueSerializer(stringSerializer);
return redisTemplate;
}
}
点击查看

本文标题:解决RedisTemplate存储至缓存数据出现乱码的情况

文章作者:LiJing

发布时间:2022年04月29日 - 17:29:44

最后更新:2023年06月03日 - 09:58:59

原始链接:https://blog-next.xiaojingge.com/posts/4208517531.html

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

-------------------本文结束 感谢您的阅读-------------------