springboot整合redis并使用json序列化器

本文介绍了如何在SpringBoot项目中整合Redis,包括pom文件添加依赖、配置类的编写,如缓存管理和RedisTemplate的设置,并展示了使用注解进行缓存的测试案例。同时,详细说明了配置序列化解决乱码问题以及设置缓存过期时间的方法。

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

pom文件引入依赖

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

添加配置类


import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.interceptor.KeyGenerator;
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.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.time.Duration;

/**
 * @author fenglu
 * @date 2021/9/8 10:45
 * @description:
 */
@EnableCaching//如果要使用注解的方式则添加该注解
@Configuration
public class RedisConfig {


    @Autowired
    RedisTemplate redisTemplate;

    @Bean
    public KeyGenerator keyGenerator() {
        return (target, method, params) -> {
            StringBuilder sb = new StringBuilder();
            sb.append(target.getClass().getName());
            sb.append(method.getName());
            for (Object obj : params) {
                sb.append(obj.toString());
            }
            return sb.toString();
        };
    }


    @Bean
    public <M, N> RedisTemplate<M, N> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<M, N> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);
        GenericJackson2JsonRedisSerializer serializer = new GenericJackson2JsonRedisSerializer();
        template.setDefaultSerializer(serializer);
        return template;
    }

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        GenericJackson2JsonRedisSerializer jackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();

        // 配置序列化(解决乱码的问题),过期时间600秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }

}

测试

  @Test
    void contextLoads() {

        try {
        	//生成一个随机的user对象
            TUser user = GenerateUserUtils.generateUser("province", "city", "county");
            //使用redisTemplate将对象放入redis
            redisTemplate.boundValueOps("user1").set(user);

        } catch (ParseException e) {
            e.printStackTrace();
        }
        //使用注解的方式将查询出来的用户加入缓存
        final TUser userById = userService.getUserById(1);
        System.out.println(userById.getUsername());
        System.out.println(userById);

    }

	//这里使用注解的方式来进行测试
	@Override
    @Cacheable(value = "users",key="#root.methodName+':'+#id")
    public TUser getUserById(Integer id) {
        return userMapper.selectById(id);
    }

缓存的注解怎么用这里不多叙述。

最终效果

在这里插入图片描述

一个简单的小案例,整合redis的原理啥的我也不是很懂,以后再补充吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值