mirror of
				https://github.com/continew-org/continew-admin.git
				synced 2025-10-25 18:57:11 +08:00 
			
		
		
		
	refactor: 适配 ContiNew Starter Redisson 自动配置
This commit is contained in:
		| @@ -23,7 +23,13 @@ | ||||
|             <artifactId>continew-starter-api-doc</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- ContiNew Starter Jackson 依赖 --> | ||||
|         <!-- ContiNew Starter Redisson 依赖(Redis 缓存) --> | ||||
|         <dependency> | ||||
|             <groupId>top.charles7c.continew</groupId> | ||||
|             <artifactId>continew-starter-cache-redisson</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- ContiNew Starter Jackson 依赖(JSON) --> | ||||
|         <dependency> | ||||
|             <groupId>top.charles7c.continew</groupId> | ||||
|             <artifactId>continew-starter-json-jackson</artifactId> | ||||
| @@ -114,12 +120,6 @@ | ||||
|             <artifactId>mica-ip2region</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- Redisson(不仅仅是一个 Redis Java 客户端) --> | ||||
|         <dependency> | ||||
|             <groupId>org.redisson</groupId> | ||||
|             <artifactId>redisson-spring-boot-starter</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|         <!-- Easy Captcha(Java 图形验证码,支持 gif、中文、算术等类型,可用于 Java Web、JavaSE 等项目) --> | ||||
|         <dependency> | ||||
|             <groupId>com.github.whvcse</groupId> | ||||
|   | ||||
| @@ -21,8 +21,6 @@ import java.util.Map; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| 
 | ||||
| import org.redisson.codec.JsonJacksonCodec; | ||||
| import org.redisson.spring.starter.RedissonAutoConfigurationCustomizer; | ||||
| import org.springframework.boot.autoconfigure.cache.CacheProperties; | ||||
| import org.springframework.cache.annotation.CachingConfigurerSupport; | ||||
| import org.springframework.cache.annotation.EnableCaching; | ||||
| @@ -41,7 +39,7 @@ import cn.hutool.crypto.digest.DigestUtil; | ||||
| import cn.hutool.json.JSONUtil; | ||||
| 
 | ||||
| /** | ||||
|  * Redis 配置 | ||||
|  * Spring Cache 配置 | ||||
|  * | ||||
|  * @author Charles7c | ||||
|  * @since 2022/12/28 23:17 | ||||
| @@ -50,19 +48,10 @@ import cn.hutool.json.JSONUtil; | ||||
| @EnableCaching | ||||
| @Configuration | ||||
| @RequiredArgsConstructor | ||||
| public class RedisConfiguration extends CachingConfigurerSupport { | ||||
| public class SpringCacheConfiguration extends CachingConfigurerSupport { | ||||
| 
 | ||||
|     private final ObjectMapper objectMapper; | ||||
| 
 | ||||
|     /** | ||||
|      * Redisson 自定义配置 | ||||
|      */ | ||||
|     @Bean | ||||
|     public RedissonAutoConfigurationCustomizer redissonCustomizer() { | ||||
|         // 解决序列化乱码问题 | ||||
|         return config -> config.setCodec(new JsonJacksonCodec(objectMapper)); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * 解决 Spring Cache(@Cacheable)缓存乱码问题 | ||||
|      */ | ||||
| @@ -19,7 +19,7 @@ package top.charles7c.cnadmin.common.config.justauth; | ||||
| import java.time.Duration; | ||||
|  | ||||
| import top.charles7c.cnadmin.common.constant.CacheConsts; | ||||
| import top.charles7c.cnadmin.common.util.RedisUtils; | ||||
| import top.charles7c.continew.starter.cache.redisson.util.RedisUtils; | ||||
|  | ||||
| import me.zhyd.oauth.cache.AuthStateCache; | ||||
|  | ||||
| @@ -42,7 +42,7 @@ public class JustAuthRedisStateCache implements AuthStateCache { | ||||
|     @Override | ||||
|     public void cache(String key, String value) { | ||||
|         // 参考:在 JustAuth 中,内置了一个基于 map 的 state 缓存器,默认缓存有效期为 3 分钟 | ||||
|         RedisUtils.setCacheObject(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key), value, | ||||
|         RedisUtils.set(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key), value, | ||||
|             Duration.ofMinutes(3)); | ||||
|     } | ||||
|  | ||||
| @@ -58,7 +58,7 @@ public class JustAuthRedisStateCache implements AuthStateCache { | ||||
|      */ | ||||
|     @Override | ||||
|     public void cache(String key, String value, long timeout) { | ||||
|         RedisUtils.setCacheObject(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key), value, | ||||
|         RedisUtils.set(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key), value, | ||||
|             Duration.ofMillis(timeout)); | ||||
|     } | ||||
|  | ||||
| @@ -71,7 +71,7 @@ public class JustAuthRedisStateCache implements AuthStateCache { | ||||
|      */ | ||||
|     @Override | ||||
|     public String get(String key) { | ||||
|         return RedisUtils.getCacheObject(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key)); | ||||
|         return RedisUtils.get(RedisUtils.formatKey(CacheConsts.SOCIAL_AUTH_STATE_KEY_PREFIX, key)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -1,221 +0,0 @@ | ||||
| /* | ||||
|  * Copyright (c) 2022-present Charles7c Authors. All Rights Reserved. | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *     http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
|  | ||||
| package top.charles7c.cnadmin.common.util; | ||||
|  | ||||
| import java.time.Duration; | ||||
| import java.util.Collection; | ||||
| import java.util.stream.Collectors; | ||||
| import java.util.stream.Stream; | ||||
|  | ||||
| import lombok.AccessLevel; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
|  | ||||
| import org.redisson.api.*; | ||||
| import org.redisson.config.Config; | ||||
|  | ||||
| import cn.hutool.extra.spring.SpringUtil; | ||||
|  | ||||
| /** | ||||
|  * Redis 工具类 | ||||
|  * | ||||
|  * @author Lion Li(RuoYi-Vue-Plus) | ||||
|  * @author Charles7c | ||||
|  * @since 2022/12/11 12:00 | ||||
|  */ | ||||
| @Data | ||||
| @NoArgsConstructor(access = AccessLevel.PRIVATE) | ||||
| public class RedisUtils { | ||||
|  | ||||
|     private static final RedissonClient REDISSON_CLIENT = SpringUtil.getBean(RedissonClient.class); | ||||
|  | ||||
|     /* ################ 查询操作 ################ */ | ||||
|     /** | ||||
|      * 获取缓存的基本对象列表 | ||||
|      * | ||||
|      * @param keyPattern | ||||
|      *            缓存键表达式 | ||||
|      * @return 基本对象列表 | ||||
|      */ | ||||
|     public static Collection<String> keys(final String keyPattern) { | ||||
|         Stream<String> stream = REDISSON_CLIENT.getKeys().getKeysStreamByPattern(getNameMapper().map(keyPattern)); | ||||
|         return stream.map(key -> getNameMapper().unmap(key)).collect(Collectors.toList()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否存在指定缓存 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      */ | ||||
|     public static Boolean hasKey(String key) { | ||||
|         RKeys rKeys = REDISSON_CLIENT.getKeys(); | ||||
|         return rKeys.countExists(getNameMapper().map(key)) > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取缓存剩余存活时间 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @return 剩余存活时间(单位:毫秒) | ||||
|      */ | ||||
|     public static <T> long getTimeToLive(final String key) { | ||||
|         RBucket<T> rBucket = REDISSON_CLIENT.getBucket(key); | ||||
|         return rBucket.remainTimeToLive(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取缓存的基本对象 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @return 缓存值 | ||||
|      */ | ||||
|     public static <T> T getCacheObject(final String key) { | ||||
|         RBucket<T> rBucket = REDISSON_CLIENT.getBucket(key); | ||||
|         return rBucket.get(); | ||||
|     } | ||||
|  | ||||
|     /* ################ 操作有效期 ################ */ | ||||
|     /** | ||||
|      * 设置过期时间 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @param timeout | ||||
|      *            过期时间 | ||||
|      * @return true 设置成功;false 设置失败 | ||||
|      */ | ||||
|     public static boolean expire(final String key, final long timeout) { | ||||
|         return expire(key, Duration.ofSeconds(timeout)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 设置过期时间 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @param duration | ||||
|      *            过期时间 | ||||
|      * @return true 设置成功;false 设置失败 | ||||
|      */ | ||||
|     public static boolean expire(final String key, final Duration duration) { | ||||
|         RBucket rBucket = REDISSON_CLIENT.getBucket(key); | ||||
|         return rBucket.expire(duration); | ||||
|     } | ||||
|  | ||||
|     /* ################ 操作基本对象 ################ */ | ||||
|     /** | ||||
|      * 缓存基本对象(Integer、String、实体类等) | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @param value | ||||
|      *            缓存值 | ||||
|      */ | ||||
|     public static <T> void setCacheObject(final String key, final T value) { | ||||
|         setCacheObject(key, value, false); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 缓存基本对象,保留当前对象 TTL 有效期 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @param value | ||||
|      *            缓存值 | ||||
|      * @param isSaveTtl | ||||
|      *            是否保留 TTL 有效期(例如: set 之前 ttl 剩余 90,set 之后还是为 90) | ||||
|      * @since Redis 6.X 以上使用 setAndKeepTTL 兼容 5.X 方案 | ||||
|      */ | ||||
|     public static <T> void setCacheObject(final String key, final T value, final boolean isSaveTtl) { | ||||
|         RBucket<T> bucket = REDISSON_CLIENT.getBucket(key); | ||||
|         if (isSaveTtl) { | ||||
|             try { | ||||
|                 bucket.setAndKeepTTL(value); | ||||
|             } catch (Exception e) { | ||||
|                 long timeToLive = bucket.remainTimeToLive(); | ||||
|                 setCacheObject(key, value, Duration.ofMillis(timeToLive)); | ||||
|             } | ||||
|         } else { | ||||
|             bucket.set(value); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 缓存基本对象(Integer、String、实体类等) | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      * @param value | ||||
|      *            缓存值 | ||||
|      * @param duration | ||||
|      *            时间 | ||||
|      */ | ||||
|     public static <T> void setCacheObject(final String key, final T value, final Duration duration) { | ||||
|         RBatch batch = REDISSON_CLIENT.createBatch(); | ||||
|         RBucketAsync<T> bucket = batch.getBucket(key); | ||||
|         bucket.setAsync(value); | ||||
|         bucket.expireAsync(duration); | ||||
|         batch.execute(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除缓存的基本对象 | ||||
|      * | ||||
|      * @param key | ||||
|      *            缓存键 | ||||
|      */ | ||||
|     public static boolean deleteCacheObject(final String key) { | ||||
|         return REDISSON_CLIENT.getBucket(key).delete(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除缓存的基本对象列表 | ||||
|      * | ||||
|      * @param keyPattern | ||||
|      *            缓存键表达式 | ||||
|      */ | ||||
|     public static void deleteKeys(final String keyPattern) { | ||||
|         REDISSON_CLIENT.getKeys().deleteByPattern(getNameMapper().map(keyPattern)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 格式化缓存键,将各子键用 : 拼接起来 | ||||
|      * | ||||
|      * @param subKeys | ||||
|      *            子键列表 | ||||
|      * @return 缓存键 | ||||
|      */ | ||||
|     public static String formatKey(String... subKeys) { | ||||
|         return String.join(":", subKeys); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据集群或单机配置,获取名称映射器 | ||||
|      * | ||||
|      * @return 名称映射器 | ||||
|      */ | ||||
|     private static NameMapper getNameMapper() { | ||||
|         Config config = REDISSON_CLIENT.getConfig(); | ||||
|         if (config.isClusterConfig()) { | ||||
|             return config.useClusterServers().getNameMapper(); | ||||
|         } | ||||
|         return config.useSingleServer().getNameMapper(); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user