需求

需要将二进制直接存入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

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐