Java SpringBoot Redis
RedisTemplate是Spring对于Redis的封装。RedisTemplate中定义了对5种数据结构操作。

  1. redisTemplate.opsForList();//操作list
  2. redisTemplate.opsForValue();//操作字符串
  3. redisTemplate.opsForCluster();//集群时使用
  4. redisTemplate.opsForGeo();//地理位置时使用
  5. redisTemplate.opsForHash();//操作hash
  6. redisTemplate.opsForSet();//操作set
  7. redisTemplate.opsForZSet();//操作有序set

StringRedisTemplate的区别

StringRedisTemplate继承RedisTemplate
它们采用的序列化策略不同:
StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplateStringRedisTemplate它们存取的数据是相互独立的。

解决办法

上文已经提及,在动手的过程中,采用的是RedisTemplate,在传递String类型的数据结构后,查看缓存会发现数据乱码现象。这时候需要修改RedisTemplate的序列化策略。

  1. RedisSerializer<String> stringSerializer = new StringRedisSerializer();
  2. redisTemplate.setKeySerializer(stringSerializer);
  3. redisTemplate.setValueSerializer(stringSerializer);
  4. redisTemplate.setHashKeySerializer(stringSerializer);
  5. redisTemplate.setHashValueSerializer(stringSerializer);

但是注意一点,由于采用了String的序列化策略,所以只接受value值类型为String的参数。
如果传递了Integer类型的参数,直接使用toString()方法存入缓存。

  1. ops.set("stock", redPacket.getStock().toString(),TIME_OUT, TimeUnit.SECONDS);

这样就解决了乱码问题。

附:SpringBoot启动实例化配置

  1. @Configuration
  2. public class RedisConfigurtion {
  3. @Autowired
  4. private RedisTemplate redisTemplate;
  5. @Bean
  6. public RedisTemplate<String, Object> stringSerializerRedisTemplate() {
  7. RedisSerializer<String> stringSerializer = new StringRedisSerializer();
  8. redisTemplate.setKeySerializer(stringSerializer);
  9. redisTemplate.setValueSerializer(stringSerializer);
  10. redisTemplate.setHashKeySerializer(stringSerializer);
  11. redisTemplate.setHashValueSerializer(stringSerializer);
  12. return redisTemplate;
  13. }
  14. }