From f78df97bccf776927658abecd186a08c8175dcbb Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期一, 29 五月 2023 21:45:09 +0800 Subject: [PATCH] fix 修复 OssClient 实例多租户相同key缓存覆盖问题 --- ruoyi-common/ruoyi-common-oss/src/main/java/org/dromara/common/oss/factory/OssFactory.java | 12 +++++++----- 1 files changed, 7 insertions(+), 5 deletions(-) diff --git a/ruoyi-common/ruoyi-common-oss/src/main/java/org/dromara/common/oss/factory/OssFactory.java b/ruoyi-common/ruoyi-common-oss/src/main/java/org/dromara/common/oss/factory/OssFactory.java index 084d89a..6503eb1 100644 --- a/ruoyi-common/ruoyi-common-oss/src/main/java/org/dromara/common/oss/factory/OssFactory.java +++ b/ruoyi-common/ruoyi-common-oss/src/main/java/org/dromara/common/oss/factory/OssFactory.java @@ -45,17 +45,19 @@ throw new OssException("绯荤粺寮傚父, '" + configKey + "'閰嶇疆淇℃伅涓嶅瓨鍦�!"); } OssProperties properties = JsonUtils.parseObject(json, OssProperties.class); - OssClient client = CLIENT_CACHE.get(configKey); + // 浣跨敤绉熸埛鏍囪瘑閬垮厤澶氫釜绉熸埛鐩稿悓key瀹炰緥瑕嗙洊 + String key = properties.getTenantId() + ":" + configKey; + OssClient client = CLIENT_CACHE.get(key); if (client == null) { - CLIENT_CACHE.put(configKey, new OssClient(configKey, properties)); + CLIENT_CACHE.put(key, new OssClient(configKey, properties)); log.info("鍒涘缓OSS瀹炰緥 key => {}", configKey); - return CLIENT_CACHE.get(configKey); + return CLIENT_CACHE.get(key); } // 閰嶇疆涓嶇浉鍚屽垯閲嶆柊鏋勫缓 if (!client.checkPropertiesSame(properties)) { - CLIENT_CACHE.put(configKey, new OssClient(configKey, properties)); + CLIENT_CACHE.put(key, new OssClient(configKey, properties)); log.info("閲嶈浇OSS瀹炰緥 key => {}", configKey); - return CLIENT_CACHE.get(configKey); + return CLIENT_CACHE.get(key); } return client; } -- Gitblit v1.9.3