redis存入map类型数据默认序列化产生的问题

一、问题发现
项目中需要将部分资源存入redis中,数据类型为hash类型,代码使用的redisTemple。

Map map = new HashMap<String,Object>();
map.put("2021-03-12","100");
redisUtil.hashMultiSet("testHash",map);

redisUtil中的代码为

    public void hashMultiSet(final String key, Map<?, ?> map) {
        HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();
        hash.putAll(key, map);
    }

运行结果为

在这里插入图片描述
通过redis可视化工具可以查看到,所有的key和value还有hashkey和hashvalue的原始字符前,都加了一串字符。查了一下,这是JdkSerializationRedisSerializer进行序列化时,加上去的。
二、问题解决
通过查询了解到现在可用的RedisSerializer主要有几种:

(1)StringRedisSerializer

(2)Jackson2JsonRedisSerializer

(3)JdkSerializationRedisSerializer

(4)GenericToStringSerializer

(5)OxmSerializer
本次使用StringRedisSerializer来序列化和反序列化redis的key值,使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值(默认使用JDK的序列化方式)

package com.chinaunicom.utils;

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
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.RedisOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

/**
 * 创建自定义redisTemplate
/
@Configuration
@ConditionalOnProperty(name = "jedis", havingValue = "true")
@ConditionalOnClass(RedisOperations.class)
public class RedisAutoConfig {

	private static Logger logger = LoggerFactory.getLogger(RedisAutoConfig.class);

	/**
	 * 自定义redisTemplate,修改序列化方式
	 */
	@Bean
	public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
		RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();
		redisTemplate.setConnectionFactory(redisConnectionFactory);

		// 使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值(默认使用JDK的序列化方式)
		Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);
		ObjectMapper mapper = new ObjectMapper();
		mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
		mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
		serializer.setObjectMapper(mapper);

		redisTemplate.setValueSerializer(serializer);
		redisTemplate.setHashValueSerializer(serializer);
		// 使用StringRedisSerializer来序列化和反序列化redis的key值
		redisTemplate.setKeySerializer(new StringRedisSerializer());
		redisTemplate.setHashKeySerializer(new StringRedisSerializer());

		redisTemplate.afterPropertiesSet();

		logger.info("Custom RedisTemplate success.");
		return redisTemplate;
	}

	@Bean
	@ConditionalOnBean(name = "redisTemplate")
	public RedisUtil redisUtils(RedisTemplate redisTemplate) {
		RedisUtil redisUtils = new RedisUtil();
		redisUtils.setRedisTemplate(redisTemplate);
		return redisUtils;
	}

}

配置类加上,完美解决当前问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值