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