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的值

redis save 乱码 redis key 乱码_redis


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

redis save 乱码 redis key 乱码_spring_02

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

redis save 乱码 redis key 乱码_java_03

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

redis save 乱码 redis key 乱码_序列化_04

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

redis save 乱码 redis key 乱码_java_05

后续我们定制RedisTemplate就可以对其进行修改

RedisSerializer提供了多种序列化方案:

三、解决乱码

1、直接调用RedisSerializer的静态方法来返回序列化器,然后set

redis save 乱码 redis key 乱码_spring_06

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

redis save 乱码 redis key 乱码_序列化_07

最后我们定制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;
    }
}

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

四、解决

redis save 乱码 redis key 乱码_序列化_08