假设现在有这种情况,我们编写一个maven工程,这里面你写了一个类,要依赖一些jar包,那么你就会去pom文件中的标签中添加你要依赖的jar的,比如:
<dependencies>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>27.1-jre</version>
</dependency>
</dependencies>
这里依赖了的jar是——guava-2.7.1-jre.jar。
之后我们使用【mvn clean package -DskipTests=true】命令打包出包——A.jar。
然后我们如果要去Linux下运行的话,那么你就需要将ScpProject-1.0-SNAPSHOT.jar和guava-27.1-jre.jar都拷贝到某个目录,然后执行类似下面的代码:
java -cp A.jar:guava-27.1-jre.jar 主类 主类参数
那么如果我们想使用如下代码就能运行呢:
java -cp A.jar 主类 主类参数
就是说我们不想带上冒号后面的jar了。(这里只是我设想的情景需求,别见怪啊~~Orz)
那么我们可以这样写:
public class TestTransfer {
static {
try {
// 包路径定义
// 获取类装载器,然后用反射方式调用类加载器的addURL方法,把新的jar路径添加进去
URLClassLoader urlLoader = (URLClassLoader) ClassLoader.getSystemClassLoader();
Class sysclass = URLClassLoader.class;
/*获取URLClassLoader的addURL方法,new Class[]{URL.class}表示参数类型 : 因为addURL方法是protected,不能直接调用*/
Method method = sysclass.getDeclaredMethod("addURL", new Class[]{URL.class});
method.setAccessible(true);
URL url = new File("/home/changshuchao/scpTest/guava-27.1-jre.jar").toURL();
URL url1 = new File("/home/changshuchao/scpTest/ganymed-ssh2-build210.jar").toURL();
/*invoke : 传递object对象及参数 调用该对象对应的方法*/
method.invoke(urlLoader, url);
method.invoke(urlLoader, url1);
} catch (Exception exp) {
exp.printStackTrace();
}
}
public static void main(String[] args) {
。。。。。
}
}
这样的话我们就可以用如下命令执行了。
java -cp A.jar 主类 主类参数
如有问题,欢迎评论交流 O(∩_∩)O~