可执行JAR忽略其自己的Class-Path属性

我使用https://stackoverflow.com/a/5893391/14731上的说明向Class-Path属性添加任意条目。 这是我的MANIFEST.MF文件:

 Manifest-Version: 1.0 Class-Path: jace-runtime.jar Main-Class: org.jace.examples.Test 

我定义了org.jace.examples.Test,如下所示:

 public class Test { public static void main(String[] args) { System.out.println("classpath: " + System.getProperty("java.class.path")); System.out.println("PeerExample: " + Class.forName("org.jace.util.ShutdownHook")); } } 

其中org.jace.util.ShutdownHookjace-runtime.jar定义。 当我调用java -jar peer_example1.jar我得到以下输出:

classpath: peer_example1.jar线程“main”中的exceptionjava.lang.ClassNotFoundException:org.jace.util.ShutdownHook

换句话说,Java正在将可执行JAR文件添加到类路径中,但忽略了Class-Path 。 如果我调用java -cp jace-runtime.jar;peer_example1.jar org.jace.examples.Test我得到预期的输出:

classpath: jace-runtime.jar;peer_example1.jar

有任何想法吗?

回答我自己的问题:

  1. 将任意条目添加到Class-Path本身就可以了。 使用以下命令启用JAR索引时会出现问题:

       true   

    Maven将省略META-INF/INDEX.LIST

  2. 在运行时使用JAR时,Java将查看INDEX.LIST以查找类,而不是MANIFEST.MF。

  3. 因为INDEX.LIST中缺少您的条目,所以无论清单显示什么,类加载器都不会找到它们。

一个简单的解决方法是禁用JAR索引。 我不确定如何在启用索引的情况下注入任意Class-Path

对于那些可能不知道的人,可执行存档机制获取清单类路径并使用它来加载存档外部的类。

因此,如果您期望使用WEB-INF / classes的清单类路径的WAR来查找存档的WEB-INF / classes条目中的类,那么您将会感到失望。

根据jar选项的tooldocs页面 – 链接到docs

使用此选项时,JAR文件是所有用户类的源,并忽略其他用户类路径设置。