| package com.ruoyi.demo.controller; | 
|   | 
| import com.ruoyi.common.core.domain.AjaxResult; | 
| import com.ruoyi.common.utils.RedisUtils; | 
| import io.swagger.annotations.Api; | 
| import io.swagger.annotations.ApiOperation; | 
| import lombok.RequiredArgsConstructor; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.cache.annotation.CacheEvict; | 
| import org.springframework.cache.annotation.CachePut; | 
| 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; | 
|   | 
| import java.util.concurrent.TimeUnit; | 
|   | 
| /** | 
|  * spring-cache 演示案例 | 
|  * | 
|  * @author Lion Li | 
|  */ | 
| // 类级别 缓存统一配置 | 
| //@CacheConfig(cacheNames = "redissonCacheMap") | 
| @Api(value = "spring-cache 演示案例", tags = {"spring-cache 演示案例"}) | 
| @RequiredArgsConstructor(onConstructor_ = @Autowired) | 
| @RestController | 
| @RequestMapping("/demo/cache") | 
| public class RedisCacheController { | 
|   | 
|     /** | 
|      * 测试 @Cacheable | 
|      * <p> | 
|      * 表示这个方法有了缓存的功能,方法的返回值会被缓存下来 | 
|      * 下一次调用该方法前,会去检查是否缓存中已经有值 | 
|      * 如果有就直接返回,不调用方法 | 
|      * 如果没有,就调用方法,然后把结果缓存起来 | 
|      * 这个注解「一般用在查询方法上」 | 
|      * <p> | 
|      * 重点说明: 缓存注解严谨与其他筛选数据功能一起使用 | 
|      * 例如: 数据权限注解 会造成 缓存击穿 与 数据不一致问题 | 
|      * <p> | 
|      * cacheNames 为配置文件内 groupId | 
|      */ | 
|     @ApiOperation("测试 @Cacheable") | 
|     @Cacheable(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") | 
|     @GetMapping("/test1") | 
|     public AjaxResult<String> test1(String key, String value) { | 
|         return AjaxResult.success("操作成功", value); | 
|     } | 
|   | 
|     /** | 
|      * 测试 @CachePut | 
|      * <p> | 
|      * 加了@CachePut注解的方法,会把方法的返回值put到缓存里面缓存起来,供其它地方使用 | 
|      * 它「通常用在新增方法上」 | 
|      * <p> | 
|      * cacheNames 为 配置文件内 groupId | 
|      */ | 
|     @ApiOperation("测试 @CachePut") | 
|     @CachePut(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") | 
|     @GetMapping("/test2") | 
|     public AjaxResult<String> test2(String key, String value) { | 
|         return AjaxResult.success("操作成功", value); | 
|     } | 
|   | 
|     /** | 
|      * 测试 @CacheEvict | 
|      * <p> | 
|      * 使用了CacheEvict注解的方法,会清空指定缓存 | 
|      * 「一般用在更新或者删除的方法上」 | 
|      * <p> | 
|      * cacheNames 为 配置文件内 groupId | 
|      */ | 
|     @ApiOperation("测试 @CacheEvict") | 
|     @CacheEvict(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") | 
|     @GetMapping("/test3") | 
|     public AjaxResult<String> test3(String key, String value) { | 
|         return AjaxResult.success("操作成功", value); | 
|     } | 
|   | 
|     /** | 
|      * 测试设置过期时间 | 
|      * 手动设置过期时间10秒 | 
|      * 11秒后获取 判断是否相等 | 
|      */ | 
|     @ApiOperation("测试设置过期时间") | 
|     @GetMapping("/test6") | 
|     public AjaxResult<Boolean> test6(String key, String value) { | 
|         RedisUtils.setCacheObject(key, value); | 
|         boolean flag = RedisUtils.expire(key, 10, TimeUnit.SECONDS); | 
|         System.out.println("***********" + flag); | 
|         try { | 
|             Thread.sleep(11 * 1000); | 
|         } catch (InterruptedException e) { | 
|             e.printStackTrace(); | 
|         } | 
|         Object obj = RedisUtils.getCacheObject(key); | 
|         return AjaxResult.success("操作成功", value.equals(obj)); | 
|     } | 
|   | 
| } |