Redis 序列化值,多了双引号问题

数据库 Redis
使用Jackson2JsonRedisSerializer​来序列化key和value​,会把Java​对象序列化为JSON​格式的字符串。如果你序列化的是Java​字符串,那么它就会被JSON​格式化,并在最终存储在Redis中时带有双引号。

问题

有两个服务:A 服务和 B 服务,A 服务负责将数据写入 Redis 的 Hash 中,B 服务负责从 Redis 中读取这些数据。在实际运行中,B 服务读取到的数字类型字符串与 A 服务写入的值不一致:

图片图片

问题排查,最终发现通过hgetall命令返回字符串多加了有引号:

图片图片

这里怀疑可能是Redis配置中的序列化参数设置导致的

序列化与反序列化

Redis序列化和反序列化是将数据结构转换为二进制格式和将二进制数据转换为对应的数据结构的过程。

序列化的作用是将数据结构转换为二进制形式,以便于传输和存储。它可以将数据保存在文件、数据库或者网络上,并能够被其他程序使用。序列化还能够对数据进行压缩,并提供灵活的数据交换格式。

反序列化则是将二进制数据转化为对应的数据结构,方便在Redis内部进行存储和查询等操作。这样可以实现对数据的读取和写入。

Redis支持多种数据结构的序列化和反序列化,包括string、hash、list、set、zset。

SpringBoot提供了多种Redis序列化方式,包括JDK序列化、JSON序列化、FastJSON序列化、Jackson序列化、Protobuf序列化等。其中JDK序列化是默认的序列化方式。

常见的序列化器

  • StringRedisSerializer:用于字符串的序列化和反序列化。适用于简单的字符串键值对。
  • Jackson2JsonRedisSerializer:使用 Jackson 库进行 JSON 序列化和反序列化。适用于复杂对象的序列化。
  • GenericJackson2JsonRedisSerializer:类似于 Jackson2JsonRedisSerializer,但可以处理泛型对象。
  • OxmMarshaler:使用 Spring 的 Object-XML 映射功能进行序列化和反序列化。适用于 XML 数据。
  • GenericToStringSerializer:将对象转换为字符串,适用于简单的对象。

A服务

使用了Jackson2JsonRedisSerializer

private RedisTemplate<String, Object> createRedisTemplate(JedisConnectionFactory connectionFactory) {
        // 序列化配置
        Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class);
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance , ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);

        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(connectionFactory);
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashKeySerializer(jackson2JsonRedisSerializer);
        redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.setDefaultSerializer(jackson2JsonRedisSerializer);
        redisTemplate.setEnableDefaultSerializer(true);
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }

B服务

此服务为c++端,使用默认String,该端不做调整的话,修复A端为new StringRedisSerializer()方式

测试

图片图片

使用StringRedisSerializer来序列化key和value,这个序列化器会把Java字符串直接转换为Redis存储的字节序列,而不添加任何额外的格式化或引号。

使用Jackson2JsonRedisSerializer来序列化key和value,会把Java对象序列化为JSON格式的字符串。如果你序列化的是Java字符串,那么它就会被JSON格式化,并在最终存储在Redis中时带有双引号。

责任编辑:武晓燕 来源: 一安未来
相关推荐

2019-11-20 10:07:23

web安全PHP序列化反序列化

2022-08-06 08:41:18

序列化反序列化Hessian

2021-03-24 08:41:38

Redis 分布式锁序列化

2011-06-01 15:05:02

序列化反序列化

2009-08-24 17:14:08

C#序列化

2021-01-20 08:24:38

序列化内存对象

2011-05-18 15:20:13

XML

2009-08-06 11:16:25

C#序列化和反序列化

2023-12-13 13:49:52

Python序列化模块

2018-03-19 10:20:23

Java序列化反序列化

2013-03-11 13:55:03

JavaJSON

2011-06-01 14:50:48

2009-06-14 22:01:27

Java对象序列化反序列化

2009-08-25 14:24:36

C#序列化和反序列化

2024-09-25 16:10:05

2011-06-01 14:26:11

序列化

2010-05-14 10:55:04

java对象序列化

2021-11-18 07:39:41

Json 序列化Vue

2009-08-25 14:43:26

C#序列化和反序列化

2012-04-13 10:45:59

XML
点赞
收藏

51CTO技术栈公众号