From 12253875406a93c2cc0f02d4abc87505e9898b15 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期日, 12 十一月 2023 20:20:03 +0800
Subject: [PATCH] 历史数据导入,单次导入超过800条报错变量溢出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