JPMS / Jigsaw缺少模块中的主类

时间:2017-12-19 01:12:12

标签: java maven executable-jar java-9 module-info

我试图创建一个模块化的可执行jar文件,可以在Java 9.0.1上使用java -p <jar file> -m <module>运行。

这在使用jar cfe test.jar test.Main -C classes/ .创建jar时会按预期工作,但在使用module test does not have a MainClass attribute, use -m <module>/<main-class>mvn package生成时会抛出mvn assembly:single

这些maven生成的jar仍可与java -p test.jar -m test/test.Main一起使用,并且所有jar都使用java -jar test.jar在类路径上工作。

我用jar xf test.jar检查了罐子里面的内容,发现罐子完全一样,除了清单(见下文):

Manifest-Version: 1.0
Created-By: 9.0.1 (Oracle Corporation)
Main-Class: test.Main

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: testuser
Build-Jdk: 9.0.1
Main-Class: test.Main

值得注意的是,在指定工作清单时,仍然无法使用java -p test.jar -m test

$ jar cfm test.jar test-contents/META-INF/MANIFEST.MF -C classes/ .
$ java -p test.jar -m test

module test does not have a MainClass attribute, use -m <module>/<main-class>

修改 :具有预期行为的回购:https://github.com/deontologic/test

1 个答案:

答案 0 :(得分:4)

我无法准确地在jar tool文档中找到这一点,但jmod tool对它的定义要好一些。

--main-class class-name 
     

指定要在module-info.class文件中记录的主类。

我可以进一步查看JDK代码和执行不同命令时的行为似乎与ModuleDescriptor.mainClass()mainClass属性相关。

由于在使用--main-class标志打包jar时,应该使模块描述符中的条目执行模块,而不在执行期间指定主类的完全限定名称。

另一方面,这不是真的using the maven jar creation,并且可能会在您未来的升级中修复。

有关以下原因的更多信息:

java -jar test-1.0.0-SNAPSHOT-jar-with-dependencies.jar

如果指定了-jar选项,则其参数是包含应用程序的类和资源文件的JAR文件的名称。启动类必须由其清单文件(Main-Class)中的META-INF/MANIFEST.MF清单标头指示

并且很明显为什么指定完全限定名称的工作原理如下:

java -p target/test-1.0.0-SNAPSHOT-jar-with-dependencies.jar -m test/test.Main