From 52f15705d063ec64a6f5bffcf50d056997c23f91 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期三, 29 十一月 2023 12:40:33 +0800
Subject: [PATCH] 鉴权服务bug修复
---
Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java | 81 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 81 insertions(+), 0 deletions(-)
diff --git a/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java b/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java
new file mode 100644
index 0000000..c4c7eb4
--- /dev/null
+++ b/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java
@@ -0,0 +1,81 @@
+package com.vci.ubcs.system.cache;
+
+import com.alibaba.nacos.api.config.ConfigFactory;
+import com.alibaba.nacos.api.config.ConfigService;
+import com.alibaba.nacos.api.exception.NacosException;
+import com.vci.ubcs.common.constant.LauncherConstant;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.cache.utils.CacheUtil;
+import org.springblade.core.secure.BladeUser;
+import org.springblade.core.tool.utils.Func;
+import org.springframework.stereotype.Component;
+import org.yaml.snakeyaml.Yaml;
+
+import java.util.Map;
+
+/**
+ * redis涓瓨鍌ㄧ殑nacos涓婇厤缃殑瓒呯閰嶇疆淇℃伅
+ * @author ludc
+ * @date 2023/8/31 13:02
+ */
+@Component
+public class NacosConfigCache {
+
+ private static final String NACOS_CONFIG_CACHE = "nacos:config";
+
+ private static final String ADMIN_INFO_CODE = "admin:info:";
+
+ private static ConfigService configService;
+
+ private static final String GROUP_ID = "DEFAULT_GROUP";
+ private static final String DATA_ID = "ubcs.yaml";
+
+ static {
+ try {
+ configService = ConfigFactory.createConfigService(LauncherConstant.NACOS_DEV_ADDR);
+ } catch (NacosException e) {
+ e.printStackTrace();
+ }
+ }
+
+ /**
+ * 闈欐�佹柟娉曚腑鑾峰彇閰嶇疆
+ * @return
+ */
+ public static Map<String, Map<String,String>> getConfig() {
+ try {
+ String config = configService.getConfig(DATA_ID, GROUP_ID, 5000);
+ Yaml yaml = new Yaml();
+ return yaml.load(config);
+ } catch (NacosException e) {
+ e.printStackTrace();
+ return null;
+ }
+ }
+
+ /**
+ * 鑾峰彇瀛樺叆redis涓�
+ * nacos涓婇厤缃殑瓒呯淇℃伅
+ * @return
+ */
+ public static BladeUser getAdminUserInfo() {
+ try {
+ BladeUser user = CacheUtil.getCache(NACOS_CONFIG_CACHE).get(ADMIN_INFO_CODE,BladeUser.class);
+ Map<String, Map<String,String>> configMap = getConfig();
+ String tenantId = configMap.get("user-info").get("tenant-id");
+ //浠庣紦瀛樹腑鏈幏鍙栧埌瓒呯骇绠$悊鍛橀厤缃俊鎭垨鑰呭拰nacos涓婇厤缃殑绉熸埛涓嶄竴鑷达紝浠巒acos涓婇噸鏂拌幏鍙栧苟瀛樺叆缂撳瓨銆�
+ if(Func.isEmpty(user) || !user.getTenantId().equals(tenantId)){
+ BladeUser adminUser = new BladeUser();
+ adminUser.setTenantId(tenantId);
+ adminUser.setUserName(configMap.get("user-info").get("user-name"));
+ adminUser.setUserId(Func.toLong(configMap.get("user-info").get("id")));
+ CacheUtil.getCache(NACOS_CONFIG_CACHE).put(ADMIN_INFO_CODE,adminUser);
+ return adminUser;
+ }
+ return user;
+ }catch (Exception e){
+ throw new ServiceException("浠巒acos涓婅幏鍙栬秴绾х鐞嗗憳閰嶇疆澶辫触锛�");
+ }
+ }
+
+}
--
Gitblit v1.9.3