Redis乱码问题
一、导入依赖,并配置文件
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
#配置redis
spring:
redis:
host: xxx.xxx.xxx.xxx
port: 6379
二、测试
@Test
void contextLoads() {
System.out.println(redisUtil.set("name", "gzl"));
System.out.println(redisUtil.get("name"));
}
发现向redis数据库中成功加入了key-value键值对,得到了value的值

但是查看库中的key发现乱码

这时候就关系到存储对象的序列化问题,在网络中传输的对象也是一样需要序列化,否者就全是乱码。我们转到看那个默认的RedisTemplate内部什么样子:

默认的RedisTemplate中的所有序列化器都是使用这个序列化器:

而默认的序列化器是采用JDK序列化器

后续我们定制RedisTemplate就可以对其进行修改
RedisSerializer提供了多种序列化方案:
三、解决乱码
1、直接调用RedisSerializer的静态方法来返回序列化器,然后set

2、自己new 相应的实现类,然后set

最后我们定制RedisTemplate的模板:
我们创建一个Bean加入容器,就会触发RedisTemplate上的条件注解使默认的RedisTemplate失效。
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
// 将template 泛型设置为 <String, Object>
RedisTemplate<String, Object> template = new RedisTemplate();
// 连接工厂,不必修改
template.setConnectionFactory(redisConnectionFactory);
/*
* 序列化设置
*/
// key、hash的key 采用 String序列化方式
template.setKeySerializer(RedisSerializer.string());
template.setHashKeySerializer(RedisSerializer.string());
// value、hash的value 采用 Jackson 序列化方式
template.setValueSerializer(RedisSerializer.json());
template.setHashValueSerializer(RedisSerializer.json());
template.afterPropertiesSet();
return template;
}
}
这样一来,只要实体类进行了序列化,我们存什么都不会有乱码的担忧了。
四、解决

博客主要围绕Java中Redis乱码问题展开。先介绍导入依赖和配置文件,测试时发现向Redis数据库添加键值对后,库中key出现乱码,这与存储对象的序列化有关。默认RedisTemplate采用JDK序列化器,后续提供了多种解决乱码的序列化方案,定制模板后可解决乱码问题。

1595

被折叠的 条评论
为什么被折叠?



