sane-service/src/main/java/org/aohe/Main.java

51 lines
1.6 KiB
Java
Raw Normal View History

2024-05-13 14:41:54 +08:00
package org.aohe;
import java.io.IOException;
import lombok.extern.slf4j.Slf4j;
import org.aohe.core.sane.utils.SaneSessionUtils;
2024-05-23 15:23:53 +08:00
import org.aohe.core.swing.MainWindow;
2024-05-15 20:24:05 +08:00
import org.aohe.core.utils.CommandUtils;
import org.aohe.core.utils.SystemUtils;
import org.aohe.core.web.SocketFactory;
2024-05-15 20:24:05 +08:00
import javax.swing.*;
@Slf4j
2024-05-13 14:41:54 +08:00
public class Main {
2024-05-15 20:24:05 +08:00
public static void main(String[] args) throws IOException, InterruptedException {
log.info(" 当前系统类型: {}", SystemUtils.getOsName());
try {
//设置窗口主题
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException |
UnsupportedLookAndFeelException e) {
throw new RuntimeException(e);
2024-05-15 20:24:05 +08:00
}
//初始化其他资源
init();
2024-05-23 15:23:53 +08:00
SwingUtilities.invokeLater(() -> new MainWindow().setVisible(true));
2024-05-13 14:41:54 +08:00
}
public static void init(){
log.info("程序初始化开始...");
CommandUtils.initSanedSocket();
stopGracefully();
log.info("Hook注册成功...");
}
public static void stopGracefully() {
log.info("优雅退出Hook注册");
//优雅退出,在程序停止时,销毁关键资源占用
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
log.info("开始资源释放");
//释放sane资源
SaneSessionUtils.resource();
SocketFactory.stop();
log.info("socket 服务已关闭 ");
}));
}
2024-05-13 14:41:54 +08:00
}