启动时打印环境配置信息

pull/31/head
hetianchen 5 years ago
parent e7d29757d2
commit 7a8e71f91e

@ -0,0 +1,71 @@
package com.ruoyi.common.log.service;
import com.ruoyi.common.log.utils.SystemInfoPrinter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import java.util.LinkedHashMap;
import java.util.Map;
/**
*
*/
@SuppressWarnings("unused")
@Component
class SystemInistService {
private SystemInistService systemInistService;
@Autowired
private Environment environment;
@PostConstruct
private void inist() {
systemInistService = this;
try {
SystemInfoPrinter.printInfo("dts 初始化信息", getSystemInfo());
} catch (Exception e) {
e.printStackTrace();
}
}
private Map<String, String> getSystemInfo() {
Map<String, String> infos = new LinkedHashMap<>();
infos.put(SystemInfoPrinter.CREATE_PART_COPPER + 0, "系统信息");
// 测试获取application-db.yml配置信息
infos.put("服务器端口", environment.getProperty("server.port"));
infos.put("数据库USER", environment.getProperty("spring.datasource.druid.username"));
infos.put("数据库地址", environment.getProperty("spring.datasource.druid.url"));
infos.put("调试级别", environment.getProperty("logging.level.com.qiguliuxing.dts.wx"));
// 测试获取application-core.yml配置信息
infos.put(SystemInfoPrinter.CREATE_PART_COPPER + 1, "模块状态");
infos.put("邮件", environment.getProperty("dts.notify.mail.enable"));
infos.put("短信", environment.getProperty("dts.notify.sms.enable"));
infos.put("模版消息", environment.getProperty("dts.notify.wx.enable"));
infos.put("快递信息", environment.getProperty("dts.express.enable"));
infos.put("快递鸟ID", environment.getProperty("dts.express.appId"));
infos.put("对象存储", environment.getProperty("dts.storage.active"));
infos.put("本地对象存储路径", environment.getProperty("dts.storage.local.storagePath"));
infos.put("本地对象访问地址", environment.getProperty("dts.storage.local.address"));
infos.put("本地对象访问端口", environment.getProperty("dts.storage.local.port"));
// 微信相关信息,屏蔽打印控制台
infos.put(SystemInfoPrinter.CREATE_PART_COPPER + 2, "微信相关");
infos.put("微信APP KEY", environment.getProperty("dts.wx.app-id"));
infos.put("微信APP-SECRET", environment.getProperty("dts.wx.app-secret"));
infos.put("微信支付MCH-ID", environment.getProperty("dts.wx.mch-id"));
infos.put("微信支付MCH-KEY", environment.getProperty("dts.wx.mch-key"));
infos.put("微信支付通知地址", environment.getProperty("dts.wx.notify-url"));
// 测试获取System表配置信息
infos.put(SystemInfoPrinter.CREATE_PART_COPPER + 3, "系统设置");
return infos;
}
}

@ -0,0 +1,72 @@
package com.ruoyi.common.log.utils;
import java.util.Map;
public class SystemInfoPrinter {
public static final String CREATE_PART_COPPER = "XOXOXOXOX";
private static int maxSize = 0;
public static void printInfo(String title, Map<String, String> infos) {
setMaxSize(infos);
printHeader(title);
for (Map.Entry<String, String> entry : infos.entrySet()) {
printLine(entry.getKey(), entry.getValue());
}
printEnd();
}
private static void setMaxSize(Map<String, String> infos) {
for (Map.Entry<String, String> entry : infos.entrySet()) {
if (entry.getValue() == null) {
continue;
}
int size = entry.getKey().length() + entry.getValue().length();
if (size > maxSize) {
maxSize = size;
}
}
maxSize = maxSize + 30;
}
private static void printHeader(String title) {
System.out.println(getLineCopper());
System.out.println("");
System.out.println(" " + title);
System.out.println("");
}
private static void printEnd() {
System.out.println(" ");
System.out.println(getLineCopper());
}
private static String getLineCopper() {
String copper = "";
for (int i = 0; i < maxSize; i++) {
copper += "=";
}
return copper;
}
private static void printLine(String head, String line) {
if (line == null) {
return;
}
if (head.startsWith(CREATE_PART_COPPER)) {
System.out.println("");
System.out.println(" [[ " + line + " ]]");
System.out.println("");
} else {
System.out.println(" " + head + " -> " + line);
}
}
}
Loading…
Cancel
Save