redis乱码问题

Redis乱码问题

一、导入依赖,并配置文件

<!-- redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>
#配置redis
spring:redis:host: xxx.xxx.xxx.xxxport: 6379

二、测试

@Testvoid 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 {@Beanpublic 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;}
}

这样一来,只要实体类进行了序列化,我们存什么都不会有乱码的担忧了。

四、解决