Redis设置value为对象

package com.pacificrehouse.push.common.config;
import com.pacificrehouse.push.bean.abnormaldeal.AbnormalDealRecordReq;
import com.pacificrehouse.push.bean.propertyid.building.PropertyIdBuildingReq;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.cache.CacheManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.cache.RedisCacheWriter;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import org.springframework.session.data.redis.config.ConfigureRedisAction;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;


/**
 * @author Zml
 * @createDate 2021-09-23
 */
@Configuration
@EnableRedisHttpSession
public class RedisConfig {

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

        // 使用Jackson2JsonRedisSerialize 替换默认的jdkSerializeable序列化
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);

        // 设置value的序列化规则和 key的序列化规则
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
        //初始化一个RedisCacheWriter
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(connectionFactory);

        Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);

        RedisSerializationContext.SerializationPair<Object> pair = RedisSerializationContext.SerializationPair.fromSerializer(serializer);

        RedisCacheConfiguration defaultCacheConfig= RedisCacheConfiguration.defaultCacheConfig().serializeValuesWith(pair);

        return new RedisCacheManager(redisCacheWriter, defaultCacheConfig);
    }
    @Bean
    public static ConfigureRedisAction configureRedisAction() {
        return ConfigureRedisAction.NO_OP;
    }

    @Bean(name = "propertyBuildingRedisTemplate")
    public RedisTemplate<String, PropertyIdBuildingReq> propertyBuildingRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, PropertyIdBuildingReq> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);

        Jackson2JsonRedisSerializer<PropertyIdBuildingReq> redisSerializer = new Jackson2JsonRedisSerializer<>(PropertyIdBuildingReq.class);
        redisTemplate.setDefaultSerializer(redisSerializer);
        RedisSerializer<String> serializer = new StringRedisSerializer();
        redisTemplate.setKeySerializer(serializer);
        return redisTemplate;

    }

    @Bean(name = "abnormalDealRecordRedisTemplate")
    public RedisTemplate<String, AbnormalDealRecordReq> AbnormalDealRecordRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, AbnormalDealRecordReq> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);

        Jackson2JsonRedisSerializer<AbnormalDealRecordReq> redisSerializer = new Jackson2JsonRedisSerializer<>(AbnormalDealRecordReq.class);
        redisTemplate.setDefaultSerializer(redisSerializer);
        RedisSerializer<String> serializer = new StringRedisSerializer();
        redisTemplate.setKeySerializer(serializer);
        return redisTemplate;

    }

}
在Java中,可以使用Redis来存储Java对象。其中,可以使用RedisTemplate的opsForHash()方法来存储Map<String, RedisCustom>对象类型数据。[1] 要存储Java对象,首先需要定义一个父类和一个子类。父类Redis实现了Serializable接口,并包含了name和age两个属性,以及相应的getter和setter方法。子类RedisCustom继承了父类Redis,还包含了一个额外的属性stuCode,并同样实现了相应的getter和setter方法。 在使用redisTemplate.opsForHash()方法时,可以将Java对象作为value存储在Redis中。可以将整个Java对象作为一个Map的value,key可以自定义,比如使用对象的唯一标识符作为key。这样,可以通过key来获取对应的Java对象。需要注意的是,在存储Java对象之前,需要确保Java对象的类已被序列化。 总结起来,要存储Java对象Redis中,需要定义一个父类和一个子类,父类实现Serializable接口,子类继承父类并添加额外的属性。然后使用redisTemplate.opsForHash()方法将Java对象作为value存储在Redis中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Java redis存Map对象类型数据](https://blog.csdn.net/m0_67391907/article/details/126387387)[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、付费专栏及课程。

余额充值