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