在 java 9-ea 中尝试使用 javapackager 打包本机图像时出错?
Error when trying to package native image with javapackager in java 9-ea?
我正在尝试 java 9-ea (jdk-9+180) 和新的 javapackager 从一个简单的模块创建原生图像,但我得到空指针异常。任何人都知道我是否太早或者我没有使用正确的命令开关来让它工作? jlink 命令工作正常但 javapackager 没有。在撰写本文时,我使用的是最新的 jdk-9+180。我已尝试使用 -native exe
和 -native image
开关,但出现相同类型的错误。我也在 Mac 上尝试过使用 -native dmg
开关创建本机 dmg,但在该平台上发生了同样的错误。我真的很想在这里使用 javapackager 以便能够在 exe/dmg
.
中捆绑构建
编辑 1:
我已经提交了关于此问题的错误报告,现在可以在以下 url 中看到它:http://bugs.java.com/bugdatabase/view_bug.do?bug_id=JDK-8186661
我的模块-info.java:
module my.module {
requires javafx.graphics;
requires javafx.fxml;
exports sample;
}
首先,我用 javapackager 创建了一个 jar,它工作正常:
C:\Java9Test\target>javapackager -createjar -appclass sample.Main -srcdir classes -outdir . -outfile myjar -v
我已经验证生成的 jar 结构看起来没问题,其中包含正确编译的 module-info.class
和其他两个 类。
以下 jlink 命令有效并生成可运行的缩减运行时映像:
C:\Java9Test\target>jlink --output release\MyTestApp --compress=2 --module-path "myjar.jar;C:\Program Files\Java\jdk-9\jmods" --add-modules my.module
但是,当尝试使用以下命令使用 javapackager 创建本机映像时失败:
C:\Java9Test\target>javapackager -deploy -v -outdir packages -name MyTestApp -native image --module-path "myjar.jar;C:\Program Files\Java\jdk-9\jmods" --add-modules my.module --module my.module/sample.Main
输出:
Running [C:\Program Files\Java\jdk-9\bin\java.exe, -version] Creating app bundle: MyTestApp in C:\Java9Test\target\packages Exception: java.lang.NullPointerException Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "Windows Application Image" (windows.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)
编辑 2:
来自 -native exe
标志的输出(在 Windows 上)
Running [C:\Program Files\Java\jdk-9\bin\java.exe, -version]
Running [C:\Program Files (x86)\Inno Setup 5\iscc.exe, /?]
Detected [C:\Program Files (x86)\Inno Setup 5\iscc.exe] version [5]
At least one type of shortcut is required. Enabling menu shortcut.
Exception: java.lang.NullPointerException
Config files are saved to C:\Users\Username\AppData\Local\Temp\fxbundler17330843784617821035\windows. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "EXE Installer" (exe) 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)
编辑 3:
来自 -native dmg
标志的输出(在 MacOSX 上)
Building DMG package for MyTestApp
Exception: java.lang.NullPointerException
Config files are saved to /var/folders/qs/nk3vxsx90q9_pbjs0ypg74r40000gn/T/fxbundler3765252041328710759/macosx. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "DMG Installer" (dmg) 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)
来自 -native deb
标志的输出(在 Linux Mint 上)
Running [dpkg-deb, --version]
Debian packages should specify a license. The absence of a license will cause some linux distributions to complain about the quality of the application.
Exception: java.lang.NullPointerException
Config files are saved to /tmp/fxbundler2941553392593775128/linux. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "DEB Installer" (deb) 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)
来自 -native rpm
标志的输出(在 Linux Mint 上)
Running [rpmbuild, --version]
At least one type of shortcut is required. Enabling menu shortcut.
Exception: java.lang.NullPointerException
Config files are saved to /tmp/fxbundler2278571164448075269/linux. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "RPM Bundle" (rpm) 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)
在这里回答我自己的问题(在收到对错误报告的回复之后):
事实证明,模块路径必须只包含目录名,而不是文件名,因此您不能像使用 jlink 命令那样在路径中指定 jar。如果设置为编译后的模块-类,javapackager 将使用模块路径,如下所示,您也不需要将模块路径放入 jmods 目录,因为它会自动获取。
C:\Java9Test\target>javapackager -deploy -v -outdir packages -name MyTestApp -native image --module-path C:\Java9Test\target\classes --module my.module/sample.Main
但是,生成的构建的可执行文件 MyTestApp.exe
对我不起作用,调用(双击)时没有任何反应。此外,该构建非常庞大,而且您似乎还不能像使用 jlink
那样使用 --compress=2
和 --strip-debug
标志。但是,我发现您实际上可以将 javapackager 生成的运行时文件夹的内容替换为 jlink 命令的输出,从而使构建的占用空间小得多,并且 MyTestApp.exe
在调用时有效!我还可以从替换的 runtime\bin
文件夹中删除 java.exe
和 javaw.exe
,以及从主 MyTestApp
文件夹中删除 msvcp120.dll
和 msvcr120.dll
因为那些 dll:s 已经在 MyTestApp\runtime\bin
文件夹中。
MyTestApp
-文件夹结构:
.
我正在尝试 java 9-ea (jdk-9+180) 和新的 javapackager 从一个简单的模块创建原生图像,但我得到空指针异常。任何人都知道我是否太早或者我没有使用正确的命令开关来让它工作? jlink 命令工作正常但 javapackager 没有。在撰写本文时,我使用的是最新的 jdk-9+180。我已尝试使用 -native exe
和 -native image
开关,但出现相同类型的错误。我也在 Mac 上尝试过使用 -native dmg
开关创建本机 dmg,但在该平台上发生了同样的错误。我真的很想在这里使用 javapackager 以便能够在 exe/dmg
.
编辑 1: 我已经提交了关于此问题的错误报告,现在可以在以下 url 中看到它:http://bugs.java.com/bugdatabase/view_bug.do?bug_id=JDK-8186661
我的模块-info.java:
module my.module {
requires javafx.graphics;
requires javafx.fxml;
exports sample;
}
首先,我用 javapackager 创建了一个 jar,它工作正常:
C:\Java9Test\target>javapackager -createjar -appclass sample.Main -srcdir classes -outdir . -outfile myjar -v
我已经验证生成的 jar 结构看起来没问题,其中包含正确编译的 module-info.class
和其他两个 类。
以下 jlink 命令有效并生成可运行的缩减运行时映像:
C:\Java9Test\target>jlink --output release\MyTestApp --compress=2 --module-path "myjar.jar;C:\Program Files\Java\jdk-9\jmods" --add-modules my.module
但是,当尝试使用以下命令使用 javapackager 创建本机映像时失败:
C:\Java9Test\target>javapackager -deploy -v -outdir packages -name MyTestApp -native image --module-path "myjar.jar;C:\Program Files\Java\jdk-9\jmods" --add-modules my.module --module my.module/sample.Main
输出:
Running [C:\Program Files\Java\jdk-9\bin\java.exe, -version] Creating app bundle: MyTestApp in C:\Java9Test\target\packages Exception: java.lang.NullPointerException Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "Windows Application Image" (windows.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)
编辑 2:
来自 -native exe
标志的输出(在 Windows 上)
Running [C:\Program Files\Java\jdk-9\bin\java.exe, -version]
Running [C:\Program Files (x86)\Inno Setup 5\iscc.exe, /?]
Detected [C:\Program Files (x86)\Inno Setup 5\iscc.exe] version [5]
At least one type of shortcut is required. Enabling menu shortcut.
Exception: java.lang.NullPointerException
Config files are saved to C:\Users\Username\AppData\Local\Temp\fxbundler17330843784617821035\windows. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "EXE Installer" (exe) 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)
编辑 3:
来自 -native dmg
标志的输出(在 MacOSX 上)
Building DMG package for MyTestApp
Exception: java.lang.NullPointerException
Config files are saved to /var/folders/qs/nk3vxsx90q9_pbjs0ypg74r40000gn/T/fxbundler3765252041328710759/macosx. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "DMG Installer" (dmg) 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)
来自 -native deb
标志的输出(在 Linux Mint 上)
Running [dpkg-deb, --version]
Debian packages should specify a license. The absence of a license will cause some linux distributions to complain about the quality of the application.
Exception: java.lang.NullPointerException
Config files are saved to /tmp/fxbundler2941553392593775128/linux. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "DEB Installer" (deb) 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)
来自 -native rpm
标志的输出(在 Linux Mint 上)
Running [rpmbuild, --version]
At least one type of shortcut is required. Enabling menu shortcut.
Exception: java.lang.NullPointerException
Config files are saved to /tmp/fxbundler2278571164448075269/linux. Use them to customize package.
Exception in thread "main" com.sun.javafx.tools.packager.PackagerException: Error: Bundler "RPM Bundle" (rpm) 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)
在这里回答我自己的问题(在收到对错误报告的回复之后):
事实证明,模块路径必须只包含目录名,而不是文件名,因此您不能像使用 jlink 命令那样在路径中指定 jar。如果设置为编译后的模块-类,javapackager 将使用模块路径,如下所示,您也不需要将模块路径放入 jmods 目录,因为它会自动获取。
C:\Java9Test\target>javapackager -deploy -v -outdir packages -name MyTestApp -native image --module-path C:\Java9Test\target\classes --module my.module/sample.Main
但是,生成的构建的可执行文件 MyTestApp.exe
对我不起作用,调用(双击)时没有任何反应。此外,该构建非常庞大,而且您似乎还不能像使用 jlink
那样使用 --compress=2
和 --strip-debug
标志。但是,我发现您实际上可以将 javapackager 生成的运行时文件夹的内容替换为 jlink 命令的输出,从而使构建的占用空间小得多,并且 MyTestApp.exe
在调用时有效!我还可以从替换的 runtime\bin
文件夹中删除 java.exe
和 javaw.exe
,以及从主 MyTestApp
文件夹中删除 msvcp120.dll
和 msvcr120.dll
因为那些 dll:s 已经在 MyTestApp\runtime\bin
文件夹中。
MyTestApp
-文件夹结构: