我正在使用javapackager
捆绑一个应用程序,其中主jar是一个带有module-info.class的模块,但它依赖于许多其他普通旧jar的jar,因此我将它们称为自动模块module-info.java。但是,javapackager
抱怨无法找到它们。如何让它找到自动模块的jar文件?
Exception: jdk.tools.jlink.plugin.PluginException: java.lang.module.FindException: Module rcf not found, required by com.username.commander.ui
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "Mac Application Image" (mac.app) failed to produce a bundle.
at jdk.packager/com.sun.javafx.tools.packager.PackagerLib.generateNativeBundles(PackagerLib.java:374)
at jdk.packager/com.sun.javafx.tools.packager.PackagerLib.generateDeploymentPackages(PackagerLib.java:348)
at jdk.packager/com.sun.javafx.tools.packager.Main.main(Main.java:496)
我试过指定模块路径(第一个dir只有主模块jar,第二个dir有所有非模块jar):
/Library/Java/JavaVirtualMachines/jdk-9.0.1.jdk/Contents/Home/bin/javapackager -deploy -native image \
-name Commander -title Commander -vendor "username" \
--module-path /Users/username/Dropbox/coding/commander/Commander-java/moduleJars:/Users/username/Dropbox/coding/commander/Commander-java/packageJars \
--module com.username.commander.ui/com.username.commander.ui.AppWindow \
-srcdir /Users/username/Dropbox/coding/commander/Commander-java/packageJars \
-outdir /Users/username/Dropbox/coding/commander/Commander-java/target \
-outfile Commander \
-Bruntime=target/jre-9.0.1 -Bicon=src/main/resources/icons/commander.icns \
-BappVersion=1.0 \
-Bmac.CFBundleIdentifier=com.username.Commander \
--add-modules java.base,java.desktop,java.naming,java.sql,java.xml,java.logging,java.management,java.scripting,java.compiler,java.rmi,java.activation \
--limit-modules java.base,java.desktop,java.naming,java.sql,java.xml,java.logging,java.management,java.scripting,java.compiler,java.rmi,java.activation \
-nosign -v
答案 0 :(得分:6)
经过更多的研究,我已经确认了nullpointer的答案:由于访问类路径,自动模块根本不受支持,这打破了Java 9模块的模块化。大约一年前的讨论中可以找到更多细节:http://mail.openjdk.java.net/pipermail/jigsaw-dev/2016-July/008559.html
因此,在Oracle和Java社区决定如何处理此问题之前,Java 9中的javapackager
允许您使用自动模块。如果捆绑使用模块的应用程序,则所有依赖项也必须是模块。如果您需要非模块依赖项,那么您必须使所有jar非模块。如果你确实使你的jar模块化,那么你必须使你的所有依赖模块化,如果你不拥有这些依赖,这可能是很多工作或不可能。
如果你把一切都变成非模块,那么当然缺点是你没有获得更简洁的运行时的优势,只包括你需要的模块。这个here有一个解决方法。
答案 1 :(得分:2)
在自动模块的实现中,进一步查看异常似乎是合理的,但该消息似乎伪装成 BUG#JDK-8189671 中所述。
似乎插件报告自动模块被用作 root因为缺少
module-info.class
资源!jlink
应该 检测尝试使用自动模块作为root前端和报告 错误。
因此,您应该为modularJars指定--module-path
。
附加说明 :Java打包工具(javapackager
)使用jlink
工具为应用程序生成自定义JRE。