Java 操作数据存入 Redis, Key出现乱码 \x00 -- 另类问题排查解决
前言:我们在使用 Java 操作redis时,或许会遇到乱码问题。虽然这些乱码可能并不影响Java程序的正常运行,但是使用 RDM 查看时redis数据时会很影响查看。以下提供一些解决办法。
·
前言:
我们在使用 Java 操作redis时,或许会遇到乱码问题。虽然这些乱码可能并不影响Java程序的正常运行,但是使用 RDM 查看时redis数据时会很影响查看。以下提供一些解决办法。
一、常规乱码问题:
一般如下进行序列化就可以解决:
/**
* retemplate相关配置
* @param redisConnectionFactory
* @return
*/
@Primary
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
// 配置连接工厂
template.setConnectionFactory(redisConnectionFactory);
// System.out.println(template.getConnectionFactory());
// json 序列化配置
Jackson2JsonRedisSerializer jsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); // 识别所有字段 PropertyAccessor 识别任何字段 JsonAutoDetect
// objectMapper.enableDefaultTyping(); // enableDefaultTyping 已过期
objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
jsonRedisSerializer.setObjectMapper(objectMapper);
// String 的 序列化
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
// key 采用 String的序列化
template.setKeySerializer(stringRedisSerializer);
// hash 的key采用String的序列化
template.setHashKeySerializer(stringRedisSerializer);
// hash 的 value 采用 String 的序列化
template.setHashValueSerializer(jsonRedisSerializer);
// value 序列化方式采用 Jackson
template.setValueSerializer(stringRedisSerializer);
template.afterPropertiesSet();
return template;
};
一、非常规乱码问题:
我前段时间通过IO流读取一行数据存入byte数组,然后byte数组转String字符串并作为主键存入redis出现乱码问题,我当时明明设置了序列化,但是依旧乱码,网上找遍也没有找到解决方法,后来通过断点调试发现了问题所在。
乱码原因:
一般我们操作IO流读取数据会创建一个 1024 容量大小的 byte[1024] 字节数组用于接收读取出来的数据。然而我们读取出来的数据可能无法填满1024个字节,这样就导致在转化成 String 类型的时候,空出的位置将会自动被填充为 \u0000 。
这就是导致存入redis 出现\x00乱码的罪魁祸首, 并不是没有设置序列化引起的乱码。那怎么解决上述问题呢?
解决很简单,只要在转化成String 过后做一次 \u0000 全部替换空即可。
new String(bytes, "utf-8").replaceAll("\\u0000", "")
更多推荐
已为社区贡献6条内容
所有评论(0)