SpringBoot整合Redis解决LocalDateTime序列化问题
Posted Kikochz
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot整合Redis解决LocalDateTime序列化问题相关的知识,希望对你有一定的参考价值。
方法一 配置类
//redis配置类
@Configuration
public class RedisConf extends CachingConfigurerSupport {
/*
配置自定义RedisTemplate
*/
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
//配置连接工厂
template.setConnectionFactory(factory);
template.setKeySerializer(keySerializer());
template.setValueSerializer(valueSerializer());
template.setHashKeySerializer(keySerializer());
template.setValueSerializer(valueSerializer());
return template;
}
/*
org.springframework.cache.interceptor包下的
自定义key的生成策略,对应@Cacheable中的keyGenerator
实例对象+方法名+参数名
*/
@Bean
public KeyGenerator keyGenerator() {
/*
target调用缓存方法的实例
method调用缓存的方法
params方法的参数
*/
return (tagert, method, params) -> {
StringBuilder sb = new StringBuilder();
sb.append(tagert.getClass().getName())
.append(method.getName());
for (Object param : params) {
sb.append(param.toString());
}
//返回key
return sb.toString();
};
}
/*
自定义缓存管理
*/
@Bean
public CacheManager cacheManager(RedisConnectionFactory factory) {
return RedisCacheManager.builder(factory).
//默认缓存策略
cacheDefaults(redisCacheConfiguration(600L)).
//配置不同缓存域,不同过期时间
withInitialCacheConfigurations(RedisCacheConfigurationMap()).
//更新删除上锁
transactionAware().
build();
}
/*
配置redis的cache策略
*/
private RedisCacheConfiguration redisCacheConfiguration(Long sec) {
return RedisCacheConfiguration.defaultCacheConfig().
//设置key的序列化,采用stringRedisSerializer
serializeKeysWith
(RedisSerializationContext.SerializationPair.fromSerializer(keySerializer())).
//设置value的序列化,采用Jackson2JsonRedis
serializeValuesWith
(RedisSerializationContext.SerializationPair.fromSerializer(valueSerializer())).
//设置cache的过期策略
entryTtl(Duration.ofSeconds(sec)).
//不缓存null的值
disableCachingNullValues();
}
/*
不同缓存域,不同过期时间,map的key可以被@Cacheable中的value使用
*/
private Map<String, RedisCacheConfiguration> RedisCacheConfigurationMap() {
Map<String, RedisCacheConfiguration> redisCacheConfigurationMap = new HashMap<>();
redisCacheConfigurationMap.put("userInfo", redisCacheConfiguration(3000L));
redisCacheConfigurationMap.put("otherInfo", redisCacheConfiguration(1000L));
return redisCacheConfigurationMap;
}
/*
key采用序列化策略
*/
private RedisSerializer<String> keySerializer() {
return new StringRedisSerializer();
}
/*
value采用序列化策略
*/
private RedisSerializer<Object> valueSerializer() {
Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class);
//序列化所有类包括jdk提供的
ObjectMapper om = new ObjectMapper();
//设置序列化的域(属性,方法etc)以及修饰范围,Any包括private,public 默认是public的
//ALL所有方位,ANY所有修饰符
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
//enableDefaultTyping 原来的方法存在漏洞,2.0后改用如下配置
//指定输入的类型
om.activateDefaultTyping(LaissezFaireSubTypeValidator.instance,
ObjectMapper.DefaultTyping.NON_FINAL);
//如果java.time包下Json报错,添加如下两行代码
om.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
om.registerModule(new JavaTimeModule());
serializer.setObjectMapper(om);
return serializer;
}
}
方法二 POJO
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@JsonSerialize(using = LocalDateTimeSerializer.class)
private LocalDateTime date;
以上是关于SpringBoot整合Redis解决LocalDateTime序列化问题的主要内容,如果未能解决你的问题,请参考以下文章