From 0936aaccea661743b37ac948b9bfec5093e1f93b Mon Sep 17 00:00:00 2001
From: MichelleChung <1242874891@qq.com>
Date: 星期六, 13 八月 2022 23:35:55 +0800
Subject: [PATCH] !215 使用Spring Cache注解优化缓存

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java |   78 +++++++++++++++++++++++++--------------
 1 files changed, 50 insertions(+), 28 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
index e0dad9f..b42248e 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
@@ -3,14 +3,14 @@
 import cn.dev33.satoken.annotation.SaCheckPermission;
 import com.ruoyi.common.constant.CacheConstants;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.utils.JsonUtils;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.common.utils.redis.RedisUtils;
+import com.ruoyi.oss.constant.OssConstant;
 import com.ruoyi.system.domain.SysCache;
-import io.swagger.v3.oas.annotations.Operation;
-import io.swagger.v3.oas.annotations.tags.Tag;
 import lombok.RequiredArgsConstructor;
-import org.springframework.data.redis.connection.RedisServerCommands;
-import org.springframework.data.redis.core.RedisCallback;
-import org.springframework.data.redis.core.RedisTemplate;
+import org.redisson.spring.data.connection.RedissonConnectionFactory;
+import org.springframework.data.redis.connection.RedisConnection;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.*;
@@ -20,34 +20,37 @@
  *
  * @author Lion Li
  */
-@Tag(name ="缂撳瓨鐩戞帶", description = "缂撳瓨鐩戞帶绠$悊")
 @RequiredArgsConstructor
 @RestController
 @RequestMapping("/monitor/cache")
 public class CacheController {
 
-    private final RedisTemplate<String, String> redisTemplate;
+    private final RedissonConnectionFactory connectionFactory;
 
     private final static List<SysCache> CACHES = new ArrayList<>();
 
     static {
         CACHES.add(new SysCache(CacheConstants.LOGIN_TOKEN_KEY, "鐢ㄦ埛淇℃伅"));
         CACHES.add(new SysCache(CacheConstants.ONLINE_TOKEN_KEY, "鍦ㄧ嚎鐢ㄦ埛"));
-        CACHES.add(new SysCache(CacheConstants.LOGIN_ERROR, "鐧婚檰閿欒"));
         CACHES.add(new SysCache(CacheConstants.SYS_CONFIG_KEY, "閰嶇疆淇℃伅"));
         CACHES.add(new SysCache(CacheConstants.SYS_DICT_KEY, "鏁版嵁瀛楀吀"));
         CACHES.add(new SysCache(CacheConstants.CAPTCHA_CODE_KEY, "楠岃瘉鐮�"));
         CACHES.add(new SysCache(CacheConstants.REPEAT_SUBMIT_KEY, "闃查噸鎻愪氦"));
         CACHES.add(new SysCache(CacheConstants.RATE_LIMIT_KEY, "闄愭祦澶勭悊"));
+        CACHES.add(new SysCache(OssConstant.SYS_OSS_KEY, "OSS閰嶇疆"));
+        CACHES.add(new SysCache(CacheConstants.PWD_ERR_CNT_KEY, "瀵嗙爜閿欒娆℃暟"));
     }
 
-    @Operation(summary = "鑾峰彇缂撳瓨鐩戞帶璇︾粏淇℃伅")
+    /**
+     * 鑾峰彇缂撳瓨鐩戞帶鍒楄〃
+     */
     @SaCheckPermission("monitor:cache:list")
     @GetMapping()
     public R<Map<String, Object>> getInfo() throws Exception {
-        Properties info = (Properties) redisTemplate.execute((RedisCallback<Object>) RedisServerCommands::info);
-        Properties commandStats = (Properties) redisTemplate.execute((RedisCallback<Object>) connection -> connection.info("commandstats"));
-        Object dbSize = redisTemplate.execute((RedisCallback<Object>) RedisServerCommands::dbSize);
+        RedisConnection connection = connectionFactory.getConnection();
+        Properties info = connection.info();
+        Properties commandStats = connection.info("commandstats");
+        Long dbSize = connection.dbSize();
 
         Map<String, Object> result = new HashMap<>(3);
         result.put("info", info);
@@ -67,53 +70,72 @@
         return R.ok(result);
     }
 
-    @Operation(summary = "鑾峰彇缂撳瓨鍚嶇О鍒楄〃")
+    /**
+     * 鑾峰彇缂撳瓨鐩戞帶缂撳瓨鍚嶅垪琛�
+     */
     @SaCheckPermission("monitor:cache:list")
     @GetMapping("/getNames")
     public R<List<SysCache>> cache() {
         return R.ok(CACHES);
     }
 
-    @Operation(summary = "鑾峰彇KEYS鍩轰簬缂撳瓨鍚�")
+    /**
+     * 鑾峰彇缂撳瓨鐩戞帶Key鍒楄〃
+     *
+     * @param cacheName 缂撳瓨鍚�
+     */
     @SaCheckPermission("monitor:cache:list")
     @GetMapping("/getKeys/{cacheName}")
-    public R<Set<String>> getCacheKeys(@PathVariable String cacheName) {
-        Set<String> cacheKyes = redisTemplate.keys(cacheName + "*");
-        return R.ok(cacheKyes);
+    public R<Collection<String>> getCacheKeys(@PathVariable String cacheName) {
+        Collection<String> cacheKeys = RedisUtils.keys(cacheName + "*");
+        return R.ok(cacheKeys);
     }
 
-    @Operation(summary = "鑾峰彇鍊煎熀浜庣紦瀛樺悕涓嶬EY")
+    /**
+     * 鑾峰彇缂撳瓨鐩戞帶缂撳瓨鍊艰鎯�
+     *
+     * @param cacheName 缂撳瓨鍚�
+     * @param cacheKey  缂撳瓨key
+     */
     @SaCheckPermission("monitor:cache:list")
     @GetMapping("/getValue/{cacheName}/{cacheKey}")
     public R<SysCache> getCacheValue(@PathVariable String cacheName, @PathVariable String cacheKey) {
-        String cacheValue = redisTemplate.opsForValue().get(cacheKey);
-        SysCache sysCache = new SysCache(cacheName, cacheKey, cacheValue);
+        Object cacheValue = RedisUtils.getCacheObject(cacheKey);
+        SysCache sysCache = new SysCache(cacheName, cacheKey, JsonUtils.toJsonString(cacheValue));
         return R.ok(sysCache);
     }
 
-    @Operation(summary = "娓呯┖缂撳瓨鍚�")
+    /**
+     * 娓呯悊缂撳瓨鐩戞帶缂撳瓨鍚�
+     *
+     * @param cacheName 缂撳瓨鍚�
+     */
     @SaCheckPermission("monitor:cache:list")
     @DeleteMapping("/clearCacheName/{cacheName}")
     public R<Void> clearCacheName(@PathVariable String cacheName) {
-        Collection<String> cacheKeys = redisTemplate.keys(cacheName + "*");
-        redisTemplate.delete(cacheKeys);
+        RedisUtils.deleteKeys(cacheName + "*");
         return R.ok();
     }
 
-    @Operation(summary = "娓呯┖缂撳瓨KEY")
+    /**
+     * 娓呯悊缂撳瓨鐩戞帶Key
+     *
+     * @param cacheKey key鍚�
+     */
     @SaCheckPermission("monitor:cache:list")
     @DeleteMapping("/clearCacheKey/{cacheKey}")
     public R<Void> clearCacheKey(@PathVariable String cacheKey) {
-        redisTemplate.delete(cacheKey);
+        RedisUtils.deleteObject(cacheKey);
         return R.ok();
     }
 
-    @Operation(summary = "娓呯┖鎵�鏈夌紦瀛�")
+    /**
+     * 娓呯悊鍏ㄩ儴缂撳瓨鐩戞帶
+     */
     @SaCheckPermission("monitor:cache:list")
     @DeleteMapping("/clearCacheAll")
     public R<Void> clearCacheAll() {
-        Collection<String> cacheKeys = redisTemplate.keys("*");
-        redisTemplate.delete(cacheKeys);
+        RedisUtils.deleteKeys("*");
         return R.ok();
     }
 

--
Gitblit v1.9.3