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;
}
}
这样一来,只要实体类进行了序列化,我们存什么都不会有乱码的担忧了。
四、解决