关于redis 取出数据转换失败的问题(invalid stream header: 7B226163)
redis 序列化问题
·
关于redis 取出数据转换失败的问题(invalid stream header: 7B226163)
invalid stream header: 7B226163
众所周知redis 是可以放对象的,但是放的对象是需要序列化的,同样拿出来的对象也是要序列化的,
这个报错就是拿出来的对象序列化时的序列器 和放入时的序列器不一样导致的,所以 针对性的指定一下即可
解决方案
可分为两种方式设置
取数据前设置
我使用的是redisTemplate 其他的几种方式自行百度,直接贴代码
redisTemplate.setValueSerializer(RedisSerializer.java());
RedisSerializer 这个是spring提供的一个工具包 里面提供了各种序列器
RedisSerializer.java();
RedisSerializer.java(ClassLoader);
RedisSerializer.byteArray();
RedisSerializer.json();
RedisSerializer.string();
顾名思义 上面几种方式都是很容易理解,分别 需要反序列化成Java类、指定类加载器的Java类、数组集合、json、string 等多种序列化器。
在使用redisTemplate 取值前 设置对应需要的序列化器即可。
启动前设置
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
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.StringRedisSerializer;
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<Object, Object> redisT(RedisConnectionFactory connectionFactory) {
RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(connectionFactory);
// 使用Jackson2JsonRedisSerialize替换默认序列化
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
// 设置key和value的序列化规则
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
}
这里设置了key,value的序列化规则
以上两种方式 先尝试一,不好使在尝试二,要注意的是在使用二的时候,要确保存取的微服务都要有这个配置类,保证一致
以上,完活
更多推荐
已为社区贡献1条内容
所有评论(0)