需求

需要将二进制直接存入redis。然而redisTemplate默认会是jdk的值序列化,就算在创建bean的时候明确设为null,并且在最后没有执行afterPropertiesSet()函数(因为这个函数会检查序列化器是否为null,若是null赋予一个jdk的),并且明确声明一个名字了,在使用@Resources引入时,也不行,依旧是jdk,如下:

 @Bean(name = "bytesRedisTemplate")
    public RedisTemplate<String, byte[]> bytesRedisTemplate2(RedisConnectionFactory connectionFactory) {
        RedisTemplate<String, byte[]> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(connectionFactory);
        // 设置key和value的序列化规则
        redisTemplate.setValueSerializer(null);
        redisTemplate.setKeySerializer(new StringRedisSerializer());
//        redisTemplate.afterPropertiesSet();

        return redisTemplate;
    }

调试看其属性:

但是引入后,调试其属性:

 

原因应该是跟注入时的spring逻辑有关,细节稍后再去看。

这里先记录下直接设置byte[]序列化方式。

代码

通过查看setValueSerializer()函数,可见其传入的是RedisSerializer:

所以看这个类发现它又内置的静态方法返回byte序列化器,另外值得一提,这个byte序列化器不是public的,所以无法new出来,那么就直接使用这个静态方法设置即可:

 

 

所以,代码如下: 

   @Bean(name = "bytesRedisTemplate")
    public RedisTemplate<String, byte[]> bytesRedisTemplate(RedisConnectionFactory connectionFactory) {
        RedisTemplate<String, byte[]> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(connectionFactory);
        // 设置key和value的序列化规则
        redisTemplate.setValueSerializer(RedisSerializer.byteArray());
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.afterPropertiesSet();

        return redisTemplate;
    }

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐