SpringBoot3 redis序列化配置

 

@Configuration
public class RedisConfig {
    @Bean
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<Object, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);

        ObjectMapper objectMapper = new ObjectMapper();
        //JsonAutoDetect.Visibility.ANY 代表所有属性或字段都可以序列化
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        //新版用法
        //以数组的方式存放到Redis,Class Type 全类名作为为第一个元素,Json字符串为第二个元素。
        objectMapper.activateDefaultTyping(objectMapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
        //老版用法,已弃用
        //objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

        // 日期序列化处理
        objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
        objectMapper.registerModule(new Jdk8Module())
                .registerModule(new JavaTimeModule())
                .registerModule(new ParameterNamesModule());

        //serializer.setObjectMapper(objectMapper);
        GenericJackson2JsonRedisSerializer serializer=
                new GenericJackson2JsonRedisSerializer(objectMapper);

        template.setKeySerializer(RedisSerializer.string());
        template.setValueSerializer(serializer);
        template.setHashKeySerializer(RedisSerializer.string());
        template.setHashValueSerializer(serializer);
        return template;
    }
    @Bean
    public ValueOperations<Object,Object> valueOperations(RedisTemplate<Object,Object> redisTemplate){
        return redisTemplate.opsForValue();
    }
    @Bean
    public HashOperations<Object,Object,Object> hashOperations(RedisTemplate<Object,Object> redisTemplate){
        return redisTemplate.opsForHash();
    }
    @Bean
    public ZSetOperations<Object,Object> zSetOperations(RedisTemplate<Object,Object> redisTemplate){
        return redisTemplate.opsForZSet();
    }
    @Bean
    public SetOperations<Object,Object> setOperations(RedisTemplate<Object,Object> redisTemplate){
        return redisTemplate.opsForSet();
    }
    @Bean
    public ListOperations<Object,Object> listOperations(RedisTemplate<Object,Object> redisTemplate){
        return redisTemplate.opsForList();
    }
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Spring Boot项目中配置Redis序列化,可以通过修改配置文件来实现。首先,需要在项目的pom.xml文件中引入Redis的相关依赖,如引用所示。然后,在application.properties或application.yml文件中添加Redis的连接配置,如引用所示。其中,spring.redis.database表示选择的数据库编号,spring.redis.host表示Redis的主机名,spring.redis.port表示Redis的端口号,spring.redis.password表示Redis的密码(如果有密码的话)。 在配置Redis序列化方式时,可以使用Spring Boot提供的默认序列化方式,也可以自定义序列化方式。如果使用默认的序列化方式,Spring Boot会将对象序列化成字节数组存储在Redis中。如果需要自定义序列化方式,可以实现RedisSerializer接口,并在配置文件中指定使用自定义的序列化方式。 要使用Spring Boot提供的默认序列化方式,只需要在配置文件中添加如下配置即可: spring.redis.serializer=org.springframework.data.redis.serializer.JdkSerializationRedisSerializer 如果想要自定义序列化方式,可以先创建一个实现了RedisSerializer接口的类,然后在配置文件中指定使用自定义的序列化方式,例如: spring.redis.serializer=com.example.MyRedisSerializer 请根据实际需求选择合适的序列化方式,并按照以上方式进行配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [SpringBoot配置redis序列化方式实战](https://blog.csdn.net/nandao158/article/details/121939312)[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: 50%"] - *3* [Spring boot 整合 Redis序列化配置](https://blog.csdn.net/weixin_43769525/article/details/109569084)[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: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值