问题背景
使用redisTemplate连接redis数据库,在保存中文时,发现存进去的key和value有乱码,也就是有\xa\xc…之类的前缀,虽然使用redisTemplate读、写redis时不会有问题,但如果通过命令行直连到redis库,就会发现数据带了乱码前缀,甚至有些中文值全是乱码。
原因
乱码是因为redisTemplate默认使用的序列化器是JdkSerializationRedisSerializer,从RedisTemplate.java源码中可以看出:
它默认的序列化器会带来乱码问题。
解决方案:
把RedisTemplate默认的序列化器改成StringRedisSerializer
// 设置redisTemplate实例的序列化方式,不然在用命令行查看redis时,会在前缀出现乱码
@Bean(name = "encodedRedisTemplate")
public RedisTemplate<String,Object> encodedRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(redisConnectionFactory);
// 把默认的序列化器改成StringRedisSerializer
RedisSerializer stringSerializer = new StringRedisSerializer();
redisTemplate.setDefaultSerializer(stringSerializer);
return redisTemplate;
}
但有个点需要注意:用了StringRedisSerializer之后,redis库的数据都是以String类型保存,所以int类型的整数,在保存时,会类型上升, 先变成double,然后再存成String,也就是1会存成"1.0",所以如果保存int数据时,需要自己在代码中单独处理下。
那么已经用旧编码方式保存的乱码数据,怎么转换成新编码的不乱码的数据呢?
还请您移步我的另一篇博客:
https://blog.youkuaiyun.com/qijingpei/article/details/108948549