redisTemplate配置序列化的原理

Spring Boot提供了对应的Starter,maven坐标:

<dependency>
<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

演示代码:

@Test
    public void  stringTest() throws Exception{
        ValueOperations valueOperations = redisTemplate.opsForValue();
        //当向Redis写入数据时,会对key跟value进行序列化,默认使用的序列化器
        //当从Redis读取数据时,会对key跟value进行反序列化
        //为什么要这么做?
        valueOperations.set("name2","jack",20,TimeUnit.SECONDS);
        String name = (String) valueOperations.get("name2");
        System.out.println(name);

        Boolean flag = valueOperations.setIfAbsent("name", "tom");
        System.out.println(flag);

        flag = valueOperations.setIfAbsent("gender", "1");
        System.out.println(flag);
    }

比如说在上面的这个测试类,我拿到了一个valueOperations操作字符的对象

,当我写入时,查看我的redis图形化工具

 

会看见写入的数据前面会加上一堆url编码,这就是它默认会在你写入的时候把你的key和value使用jdk序列化器给序列化掉。

进入RedisTemplate的源码,你会看到他继承RedisAccrssor。

 

RedisTemplate也重写这个方法,defaultSerializer是默认的序列化器,当它为空的时候,就会默认使用JdkSerializationRedisSerializer序列化器。

 看成员变量

 enableDefaultSerializer为true,所以你的Key和value就会使用下面的默认的序列化器(hash也是使用着默认的序列化器)。

 defaultUsed就是告诉你有没有使用序列化器,没有就是false和有就是true。

 

 

这段代码告诉你enableDefaultSerializer 有没有开启, defaulUsed序列化器有没有使用如果两者成立,defaultSerializer是不是空的如果是的话,默认序列化器是空的,不能序列化,请将所有序列化进行初始化。

所以当从Redis读取数据时,会对key跟value进行反序列化,之所有这么做的原因就是为了安全考虑,但是呢?

我们真正工作中,只需要序列化value不需要序列化key,这样做既可以保障安全,还能提升性能。

我们如果想要达到只对value序列化,而不对key序列化那么就要重新构造RedisTemplate,key使用String序列化器,value使用jdk序列化器。

进入RedisAutoConfiguration自动化配置

 

如果你没有设置上图被选中的代码,那么默认就是使用它,所以你要copy选中的代码,写一个Redis的配置类。

进入RedisSerializer接口你可以 选中按crtl+H 你会发很多的序列化器

键一般都使用StringRedisSerializer

自己配置的RedisConfiguration类

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以通过自定义RedisTemplate方式配置序列化。首先,你需要创建一个RedisConfig的配置类,并在该类中创建一个方法来定义RedisTemplate对象。在这个方法中,你可以设置连接工厂,并创建一个JSON序列化工具。然后,你需要设置key和value的序列化方式,可以使用RedisSerializer.string()方法来进行字符串序列化,使用GenericJackson2JsonRedisSerializer来进行JSON序列化。最后,返回RedisTemplate对象。下面是一个示例代码: @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(connectionFactory); GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer(); template.setKeySerializer(RedisSerializer.string()); template.setHashKeySerializer(RedisSerializer.string()); template.setValueSerializer(jsonRedisSerializer); template.setHashValueSerializer(jsonRedisSerializer); return template; } } 通过以上配置,你就可以使用自定义的RedisTemplate来进行序列化了。同时,你也可以使用StringRedisTemplate进行序列化,它会将值以字符串的形式存储到Redis中。要注入自定义的RedisTemplate,你可以使用@Autowired注解来进行注入,如下所示: @Autowired private RedisTemplate<String, Object> redisTemplate; 这样,你就可以在代码中使用注入的redisTemplate对象进行操作了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [RedisTemplate 的两种序列化方式](https://blog.csdn.net/weixin_43252521/article/details/123528536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值