sprin提供的RedisTemplate默认使用的是JDK的序列化,在程序中读写没有问题,但如果在redis的图形化客户端读取程序中存的值会出现乱码。
解决方法:使用自己定义的RedisTemplate,并指定序列化方式
package com.ma.config;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<Object, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
// 序列化的时候,自动推断类型,将类型信息作为属性写入JSON
// 反序列化时候,根据类型的全类名,序列化成对应的对象实例
objectMapper.activateDefaultTyping(objectMapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
//普通key序列化工具
template.setKeySerializer(RedisSerializer.string());
template.setValueSerializer(jackson2JsonRedisSerializer);
//hash 小key 序列化工具
template.setHashKeySerializer(jackson2JsonRedisSerializer);
template.setHashValueSerializer(jackson2JsonRedisSerializer);
return template;
}
}
代码中如果使用RedisTemplate要使用@Resources注解注入,这个会根据名称注入。如果使用@Autowired注解会根据类型注入,因为泛型匹配不上,运行时控制台会报错。
此外如果使用代码获取redis中所存储的值时,会统一放回Object类型,如果想要返回自己的实体类型可以使用ListOperations
、ValueOperations
、SetOperations
、ZSetOperations
、HashOperations等。只需注入的时候使用@Resources HashOperations hashOperations。