From 9b4433fddf5b401edb0aace8a404ac733b122702 Mon Sep 17 00:00:00 2001
From: 田源 <tianyuan@vci-tech.com>
Date: 星期四, 03 四月 2025 14:35:02 +0800
Subject: [PATCH] 添加非密字段显示
---
Source/BladeX-Tool/blade-core-launch/src/main/java/org/springblade/core/launch/BladeApplication.java | 130 +++++++++++++++++++++++++++++++++++++++++++
1 files changed, 130 insertions(+), 0 deletions(-)
diff --git a/Source/BladeX-Tool/blade-core-launch/src/main/java/org/springblade/core/launch/BladeApplication.java b/Source/BladeX-Tool/blade-core-launch/src/main/java/org/springblade/core/launch/BladeApplication.java
new file mode 100644
index 0000000..34c52b6
--- /dev/null
+++ b/Source/BladeX-Tool/blade-core-launch/src/main/java/org/springblade/core/launch/BladeApplication.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * Neither the name of the dreamlu.net developer nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ * Author: Chill 搴勯獮 (smallchill@163.com)
+ */
+package org.springblade.core.launch;
+
+import org.springblade.core.launch.constant.AppConstant;
+import org.springblade.core.launch.constant.NacosConstant;
+import org.springblade.core.launch.service.LauncherService;
+import org.springframework.boot.builder.SpringApplicationBuilder;
+import org.springframework.context.ConfigurableApplicationContext;
+import org.springframework.core.env.*;
+import org.springframework.util.Assert;
+import org.springframework.util.StringUtils;
+
+import java.nio.charset.StandardCharsets;
+import java.util.*;
+import java.util.function.Function;
+import java.util.stream.Collectors;
+
+/**
+ * 椤圭洰鍚姩鍣紝鎼炲畾鐜鍙橀噺闂
+ *
+ * @author Chill
+ */
+public class BladeApplication {
+
+ /**
+ * Create an application context
+ * java -jar app.jar --spring.profiles.active=prod --server.port=2333
+ *
+ * @param appName application name
+ * @param source The sources
+ * @return an application context created from the current state
+ */
+ public static ConfigurableApplicationContext run(String appName, Class source, String... args) {
+ SpringApplicationBuilder builder = createSpringApplicationBuilder(appName, source, args);
+ return builder.run(args);
+ }
+
+ public static SpringApplicationBuilder createSpringApplicationBuilder(String appName, Class source, String... args) {
+ Assert.hasText(appName, "[appName]鏈嶅姟鍚嶄笉鑳戒负绌�");
+ // 璇诲彇鐜鍙橀噺锛屼娇鐢╯pring boot鐨勮鍒�
+ ConfigurableEnvironment environment = new StandardEnvironment();
+ MutablePropertySources propertySources = environment.getPropertySources();
+ propertySources.addFirst(new SimpleCommandLinePropertySource(args));
+ propertySources.addLast(new MapPropertySource(StandardEnvironment.SYSTEM_PROPERTIES_PROPERTY_SOURCE_NAME, environment.getSystemProperties()));
+ propertySources.addLast(new SystemEnvironmentPropertySource(StandardEnvironment.SYSTEM_ENVIRONMENT_PROPERTY_SOURCE_NAME, environment.getSystemEnvironment()));
+ // 鑾峰彇閰嶇疆鐨勭幆澧冨彉閲�
+ String[] activeProfiles = environment.getActiveProfiles();
+ // 鍒ゆ柇鐜:dev銆乼est銆乸rod
+ List<String> profiles = Arrays.asList(activeProfiles);
+ // 棰勮鐨勭幆澧�
+ List<String> presetProfiles = new ArrayList<>(Arrays.asList(AppConstant.DEV_CODE, AppConstant.TEST_CODE, AppConstant.PROD_CODE));
+ // 浜ら泦
+ presetProfiles.retainAll(profiles);
+ // 褰撳墠浣跨敤
+ List<String> activeProfileList = new ArrayList<>(profiles);
+ Function<Object[], String> joinFun = StringUtils::arrayToCommaDelimitedString;
+ SpringApplicationBuilder builder = new SpringApplicationBuilder(source);
+ String profile;
+ if (activeProfileList.isEmpty()) {
+ // 榛樿dev寮�鍙�
+ profile = AppConstant.DEV_CODE;
+ activeProfileList.add(profile);
+ builder.profiles(profile);
+ } else if (activeProfileList.size() == 1) {
+ profile = activeProfileList.get(0);
+ } else {
+ // 鍚屾椂瀛樺湪dev銆乼est銆乸rod鐜鏃�
+ throw new RuntimeException("鍚屾椂瀛樺湪鐜鍙橀噺:[" + StringUtils.arrayToCommaDelimitedString(activeProfiles) + "]");
+ }
+ String startJarPath = BladeApplication.class.getResource("/").getPath().split("!")[0];
+ String activePros = joinFun.apply(activeProfileList.toArray());
+ System.out.printf("----鍚姩涓紝璇诲彇鍒扮殑鐜鍙橀噺:[%s]锛宩ar鍦板潃:[%s]----%n", activePros, startJarPath);
+ Properties props = System.getProperties();
+ props.setProperty("spring.application.name", appName);
+ props.setProperty("spring.profiles.active", profile);
+ props.setProperty("info.version", AppConstant.APPLICATION_VERSION);
+ props.setProperty("info.desc", appName);
+ props.setProperty("file.encoding", StandardCharsets.UTF_8.name());
+ props.setProperty("blade.env", profile);
+ props.setProperty("blade.name", appName);
+ props.setProperty("blade.is-local", String.valueOf(isLocalDev()));
+ props.setProperty("blade.dev-mode", profile.equals(AppConstant.PROD_CODE) ? "false" : "true");
+ props.setProperty("blade.service.version", AppConstant.APPLICATION_VERSION);
+ props.setProperty("loadbalancer.client.name", appName);
+ Properties defaultProperties = new Properties();
+ defaultProperties.setProperty("spring.main.allow-bean-definition-overriding", "true");
+ defaultProperties.setProperty("spring.sleuth.sampler.percentage", "1.0");
+ defaultProperties.setProperty("spring.cloud.alibaba.seata.tx-service-group", appName.concat(NacosConstant.NACOS_GROUP_SUFFIX));
+ defaultProperties.setProperty("spring.cloud.nacos.config.file-extension", NacosConstant.NACOS_CONFIG_FORMAT);
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[0].data-id", NacosConstant.sharedDataId());
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[0].group", NacosConstant.NACOS_CONFIG_GROUP);
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[0].refresh", NacosConstant.NACOS_CONFIG_REFRESH);
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[1].data-id", NacosConstant.sharedDataId(profile));
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[1].group", NacosConstant.NACOS_CONFIG_GROUP);
+ defaultProperties.setProperty("spring.cloud.nacos.config.shared-configs[1].refresh", NacosConstant.NACOS_CONFIG_REFRESH);
+ builder.properties(defaultProperties);
+ // 鍔犺浇鑷畾涔夌粍浠�
+ List<LauncherService> launcherList = new ArrayList<>();
+ ServiceLoader.load(LauncherService.class).forEach(launcherList::add);
+ launcherList.stream().sorted(Comparator.comparing(LauncherService::getOrder)).collect(Collectors.toList())
+ .forEach(launcherService -> launcherService.launcher(builder, appName, profile, isLocalDev()));
+ return builder;
+ }
+
+ /**
+ * 鍒ゆ柇鏄惁涓烘湰鍦板紑鍙戠幆澧�
+ *
+ * @return boolean
+ */
+ public static boolean isLocalDev() {
+ String osName = System.getProperty("os.name");
+ return StringUtils.hasText(osName) && !(AppConstant.OS_NAME_LINUX.equalsIgnoreCase(osName));
+ }
+
+}
--
Gitblit v1.9.3