@Cacheable缓存,自定义分组缓存时间、自定义缓存key(读取类+方法+参数)

参考:SpringBoot 缓存之 @Cacheable介绍-CSDN博客

java 复制代码
package com.ruoyi.project.tool.cache;

import com.ruoyi.project.system.domain.SysUser;
import lombok.extern.slf4j.Slf4j;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/redisTest")
@Slf4j
public class CacheTestController {

//    http://localhost:9876/redisTest/cache?userId=6&userName=zhangsan
    @GetMapping("/cache")
    @Cacheable(cacheNames = "User", keyGenerator = "cacheKeyGenerator")
    public Object cache(SysUser sysUser){
        log.info("sysUser: {}", sysUser);
        return sysUser;
    }
}
复制代码
CacheConfig
java 复制代码
package com.ruoyi.framework.config.cache;

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.cache.annotation.EnableCaching;
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.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.time.Duration;
import java.util.HashMap;
import java.util.Map;

@Configuration
@EnableCaching
public class CacheConfig {

    /**
     * CacheManager为一个接口,RedisCacheManager为该接口的实现
     * redisConnectionFactory 连接工厂
     * cacheDefaults 默认配置
     *
     * @param redisConnectionFactory
     * @return
     */
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        RedisCacheManager redisCacheManager = RedisCacheManager.builder(redisConnectionFactory)
                .cacheDefaults(defaultCacheConfig(10000))
                .withInitialCacheConfigurations(initCacheConfigMap())
                .transactionAware()
                .build();
        return redisCacheManager;

    }

    /**
     * 默认配置中进行了序列化的配置
     *
     * @param second
     * @return
     */
    private RedisCacheConfiguration defaultCacheConfig(Integer second) {
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

        //解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);

        //配置序列化 解决乱码的问题
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(second))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();

        return config;

    }

    /**
     * 针对不同的redis的key 有不同的过期时间
     *
     * @return
     */
    private Map<String, RedisCacheConfiguration> initCacheConfigMap() {

        Map<String, RedisCacheConfiguration> configMap = new HashMap<>();
        configMap.put("User", this.defaultCacheConfig(10 * 60));
        configMap.put("User1", this.defaultCacheConfig(1000));
        return configMap;
    }

}
复制代码
CacheKeyGenerator
java 复制代码
package com.ruoyi.framework.config.cache;

import lombok.extern.slf4j.Slf4j;
import org.springframework.cache.interceptor.KeyGenerator;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;

import java.lang.reflect.Method;


@Slf4j
@Component
public class CacheKeyGenerator implements KeyGenerator {

    @Override
    public Object generate(Object target, Method method, Object... params) {
//        log.info("===CacheKeyGenerator generate 19 --->target: {}, method: {}, params: {}", target, method, params);
        StringBuilder sb = new StringBuilder();
        sb.append(target.getClass().getName())
                .append(".")
                .append(method.getName())
                .append(":")
                .append(StringUtils.arrayToDelimitedString(params, "_"));// !注意,记得重写参数的toString哦
        log.info("===CacheKeyGenerator generate 27 --->sb: {}", sb);
        return sb.toString();
    }
}
相关推荐
v***598315 分钟前
springBoot连接远程Redis连接失败(已解决)
spring boot·redis·后端
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-企业级软件研发工程应用规范实现细节
大数据·开发语言·人工智能·spring boot
5***b972 小时前
Spring Boot--@PathVariable、@RequestParam、@RequestBody
java·spring boot·后端
Codeking__2 小时前
Redis的value类型介绍——set
数据库·redis·缓存
qq_318121592 小时前
Java大厂面试故事:Spring Boot、微服务与AI场景深度解析
java·spring boot·redis·微服务·ai·kafka·spring security
L***d6702 小时前
Spring Boot(七):Swagger 接口文档
java·spring boot·后端
袁慎建3 小时前
如何发布自定义 Spring Boot Starter
spring boot
haokan_Jia3 小时前
【一、地质灾害气象风险预警互联系统-自由编辑预警区域,打包生成预警成果】
spring boot
一只专注api接口开发的技术猿3 小时前
如何处理淘宝 API 的请求限流与数据缓存策略
java·大数据·开发语言·数据库·spring
计算机毕设指导64 小时前
基于微信小程序的丽江市旅游分享系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·旅游