redis java序列化_java处理redis的几种序列化策略

本文介绍了SpringBoot中处理Redis的两种模板类StringRedisTemplate和RedisTemplate,详细讲解了它们的区别和使用场景。重点在于如何改写RedisTemplate的序列化策略,采用Jackson2JsonRedisSerializer,使得在存取复杂对象时无需实现Serializable接口,简化操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单记录一下java处理redis的几种序列化策略,这里使用的环境是springboot 2.0.4

springboot中提供了StringRedisTemplate和RedisTemplate两种序列化类,它们都只能读自己存的数据,即数据互不相通。

主要区别如下:

1、采用的序列化策略不同

StringRedisTemplate采用的是String的序列化策略;RedisTemplate默认采用的是jdk的序列化策略

2、存的数据形式不同

StringRedisTemplate存的是字符串;RedisTemplate存的是字节数组,在redis-cli中看好像乱码

3、使用范围不同

StringRedisTemplate只能处理字符串类型的数据,如果存取复杂的对象,又不想做额外的处理,最好用RedisTemplate

改写RedisTemplate:

我们可以改写RedisTemplate的序列化策略,比如使用Jackson2JsonRedisSerializer(还有很多),如下:

@Configurationpublic classRedisConfig {

@Bean

@ConditionalOnMissingBean(name= "redisTemplate")public RedisTemplateredisTemplate(RedisConnectionFactory redisConnectionFactory) {

RedisTemplate template = new RedisTemplate<>();//使用fastjson序列化

Jackson2JsonRedisSerializer fastJsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);//value的序列化采用fastJsonRedisSerializer

template.setValueSerializer(fastJsonRedisSerializer);

template.setHashValueSerializer(fastJsonRedisSerializer);//key的序列化采用StringRedisSerializer

template.setKeySerializer(newStringRedisSerializer());

template.setHashKeySerializer(newStringRedisSerializer());

template.setConnectionFactory(redisConnectionFactory);returntemplate;

}

}

与默认的JdkSerializationRedisSerializer相比,好处之一是存取对象不用实现Serializable接口,Jackson2Json中已做处理。

使用示例:

... ...

@Autowiredprivate RedisTemplateredisTemplate;public voidtestSetUser() {

User user=new User(1,"哈哈",20);

redisTemplate.opsForValue().set("user",user);

}public voidtestGetUser() {

User user=(User)redisTemplate.opsForValue().get("user");

System.out.println(user.getName());

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值