springboot 2.1.3
RedisTemplate配置
@Configuration
@EnableCaching
public class RedisCacheConfig extends CachingConfigurerSupport {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory connectionFactory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
//使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值
Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper mapper = new ObjectMapper();
mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
serializer.setObjectMapper(mapper);
template.setConnectionFactory(connectionFactory);
template.setValueSerializer(serializer);
//使用StringRedisSerializer来序列化和反序列化redis的key值
template.setKeySerializer(new StringRedisSerializer());
template.afterPropertiesSet();
return template;
}
}
封装一个redis工具类
@Component
public class RedisUtil {
private static final String HASH_TOKEN_KEY = "token";
@Autowired
private RedisTemplate<String,Object> redisTemplate;
/**
* 添加token
* @param key
* @param value
*/
public void putToken(String key,Object value){
redisTemplate.opsForHash().put(HASH_TOKEN_KEY,key,value);
//设置过期时间为30分钟
redisTemplate.expire(HASH_TOKEN_KEY,30, TimeUnit.MINUTES);
}
/**
* 获取token
* @param key
* @return
*/
public Token getToken(String key){
Token token = (Token) redisTemplate.opsForHash().get(HASH_TOKEN_KEY,key);
return token;
}
/**
* 删除一个token
* @param key
* @return
*/
public boolean removeToken(String key){
long res = redisTemplate.opsForHash().delete(HASH_TOKEN_KEY,key);
return res == 1 ? true:false;
}
}
注意:
1,我这里token是自己封装的一个bean,在redis的hash数据结构里是key-value,key可以uuid生成,主要是发给客户端保存的,客户端每次请求都要在请求头里面包含key值,然后拦截器根据key找到token1进行验证等
2,StringRedisTemplate是RedisTemplate<String,String>,不能用来操作token,类型转换通不过。
3,redis 的hash数据结构的过期时间还不明白是算每条数据还是一整个hash的,还未验证。