@Autowired
private StringRedisTemplate redisTemplate;
@Autowired
private RedisTemplate redisTemplate;
上下两个相同但是使用下面的会出现乱码问题得使用
@Configuration
public class RedisConfig {
@Bean(name = "redisTemplate")
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<Object, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
//定制化 专为值定制的序列化工具
Jackson2JsonRedisSerializer jacksonSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jacksonSerializer.setObjectMapper(om);
//转为key设置的序列化工具
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
//设置定制化的序列化工具
// 在使用注解@Bean返回RedisTemplate的时候,同时配置hashKey与hashValue的序列化方式。
// key采用String的序列化方式
template.setKeySerializer(stringRedisSerializer);
// value序列化方式采用jackson
template.setValueSerializer(jacksonSerializer);
// hash的key也采用String的序列化方式
template.setHashKeySerializer(stringRedisSerializer);
// hash的value序列化方式采用jackson
template.setHashValueSerializer(jacksonSerializer);
template.afterPropertiesSet();
//定制化结束
return template;
}
}
ListOperations、ValueOperations、SetOperations、ZSetOperations、HashOperations接口如何使用
@Resource(name="redisTemplate")
private ValueOperations valueOperations;
后面的依次类推。
为什么使用Resource注解是因为 ValueOperations是StringRedisTemplate的子类
这是redisTemplate可以选择的
ValueOperations<String, String> ValueOperations1 = redisTemplate.opsForValue();
这是选择redisTemplate.opforValue().的东西会发现与下面直接用 ValueOperations是一样的
所以选择ValueOperations是跳过了redisTemplate.opforValue().但是实现结果都是一样的