服务器获取Jar包运行目录

使用JAVA标准库获取运行在服务器上 Jar 包所在目录

  1. System.getProperty("user.dir")

    可直接获取Jar包启动运行的目录

    (/usr/local/test/app.jar ---> /usr/local/test)

  2. 与方法1不同,获取的是jar包真实运行的路径(!/BOOT-INF/classes!/)

java 复制代码
import java.io.File;
import java.net.URL;
import java.security.CodeSource;
import java.security.ProtectionDomain;
  
    public static String getJarPath(Class<?> clazz) {
        ProtectionDomain protectionDomain = clazz.getProtectionDomain();
        CodeSource codeSource = protectionDomain.getCodeSource();
        URL location = codeSource.getLocation();

        // 服务器:
        // file:/usr/local/test/api/app-api-0.0.1-SNAPSHOT.jar!/BOOT-INF/classes!/
        String jarPath = location.getPath();
        // 截取有效路径:
        // /usr/local/test/api/app-api-0.0.1-SNAPSHOT.jar
        String reallyPath = jarPath.substring(jarPath.indexOf(":") + 1, jarPath.indexOf("!"));
        // 获取jar包文件的父目录
        File jarFile = new File(reallyPath);
        if (jarFile != null) {
        	///usr/local/test/api
            return jarFile.getParent();
        }
        return null;
    }

3.总结

ProtectionDomain 和 CodeSource 类的主要作用是获取 当前运行应用程序 的 JAR 包路径。与直接使用 System.getProperty("user.dir") 方法相比,两者有一些区别和适用场景。

System.getProperty("user.dir"):

优点:简单、直接,无需额外依赖

缺点:它返回的是当前工作目录(即启动 Java 进程所在的目录),而不一定是正在运行的 JAR 包所在的路径 。如果应用程序是作为 JAR 文件运行的,那么这个方法将会返回启动 JAR 的目录,而不是 JAR 文件本身的路径。

ProtectionDomain 和 CodeSource:

优点:可以获取正在运行的 JAR 包的路径,适用于以 JAR 文件形式运行的应用程序

缺点:相对比较复杂,需要使用 Java 标准库的类和方法,可能涉及到一些异常处理

所以,选择哪种方法取决于你的具体需求和应用程序的运行方式。如果你只需要获取当前工作目录或启动 JAR 的目录,且不关心 JAR 文件所在路径,那么使用 System.getProperty("user.dir") 方法是更简单和直接的选择。但如果你需要获取正在运行的 JAR 文件的路径,并且应用程序是作为 JAR 文件运行的,那么使用 ProtectionDomain 和 CodeSource 类可以提供准确的 JAR 包路径信息。

相关推荐
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
海绵不是宝宝8174 小时前
连接远程服务器上的 jupyter notebook,解放本地电脑
服务器·jupyter·github
一叶飘零_sweeeet5 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
艾伦~耶格尔5 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
一只叫煤球的猫6 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心6 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算
JH30736 小时前
Maven的三种项目打包方式——pom,jar,war的区别
java·maven·jar
带刺的坐椅7 小时前
轻量级流程编排框架,Solon Flow v3.5.0 发布
java·solon·workflow·flow·solon-flow
David爱编程8 小时前
线程调度策略详解:时间片轮转 vs 优先级机制,面试常考!
java·后端
繁星¹⁸⁹⁵8 小时前
通过update-alternatives可以实现cuda的多版本切换
服务器