Java Gradle jpackage创建不可命名的应用程序
我试图用一个简陋的GradleJavaFX应用程序运行jpackage,主要是为了尝试一下。它没有什么特别之处,它是添加了Gradle的IntellijJavaFX示例。应用程序在Java Gradle jpackage创建不可命名的应用程序,java,gradle,javafx,java-11,jpackage,Java,Gradle,Javafx,Java 11,Jpackage,我试图用一个简陋的GradleJavaFX应用程序运行jpackage,主要是为了尝试一下。它没有什么特别之处,它是添加了Gradle的IntellijJavaFX示例。应用程序在gradlew clean build运行时运行良好。但是,使用gradlew jpackage创建包时,生成的exe会立即崩溃并创建hs_err_pid # A fatal error has been detected by the Java Runtime Environment: # # EXCEPTION_
gradlew clean build运行时运行良好。但是,使用gradlew jpackage
创建包时,生成的exe会立即崩溃并创建hs_err_pid
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x0000000000000000, pid=1132, tid=15340
#
# JRE version: (15.0.2+10) (build )
# Java VM: OpenJDK 64-Bit Server VM (15.0.2+10, mixed mode, tiered, compressed oops, g1 gc, windows-amd64)
# Problematic frame:
# C 0x0000000000000000
请参见此处的完整输出:
我已经试过了答案,但都不起作用
- 正在将
zip.dll
从{app}\runtime\bin
复制到{app}\
- 尝试其他JDK
- 采用OpenJDK 11
- 采用OpenJDK 14
- 采用OpenJDK15
- BellSoft Liberica JDK 15
build.gradle看起来像这样
// Setup Gradle
plugins {
id "application"
id "org.beryx.runtime" version "1.12.2"
id "org.openjfx.javafxplugin" version '0.0.9'
}
repositories {
mavenCentral()
jcenter()
}
// Setup application, dependencies
group = "io.mattw.sample"
sourceCompatibility = 15
targetCompatibility = 15
application {
mainClassName = "io.mattw.sample.Main"
}
javafx {
version = 15
modules = ["javafx.base", "javafx.controls", "javafx.fxml"]
}
dependencies {
}
// Setup release
// https://simply-how.com/custom-java-runtime
runtime {
addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
}
tasks.runtime.doLast {
copy {
from("src/main/resources")
into("$buildDir/image/bin")
}
}
编辑:
使用运行exe时,我得到以下输出。可能相关的是,我已经正常安装了Java8,尽管我希望它使用捆绑的SDK,而不是系统
Microsoft (R) Windows Debugger Version 10.0.21306.1007 AMD64
Copyright (c) Microsoft Corporation. All rights reserved.
CommandLine: C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\gradle-test-javafx.exe
************* Path validation summary **************
Response Time (ms) Location
Deferred srv*
Symbol search path is: srv*
Executable search path is:
ModLoad: 00007ff6`995d0000 00007ff6`9963f000 image00007ff6`995d0000
ModLoad: 00007ffc`36450000 00007ffc`36646000 ntdll.dll
ModLoad: 00007ffc`35320000 00007ffc`353dd000 C:\WINDOWS\System32\KERNEL32.DLL
ModLoad: 00007ffc`33d90000 00007ffc`34059000 C:\WINDOWS\System32\KERNELBASE.dll
ModLoad: 00007ffc`36210000 00007ffc`363b0000 C:\WINDOWS\System32\USER32.dll
ModLoad: 00007ffc`33d30000 00007ffc`33d52000 C:\WINDOWS\System32\win32u.dll
ModLoad: 00007ffc`346f0000 00007ffc`3471a000 C:\WINDOWS\System32\GDI32.dll
ModLoad: 00007ffc`343a0000 00007ffc`344ab000 C:\WINDOWS\System32\gdi32full.dll
ModLoad: 00007ffc`33c90000 00007ffc`33d2d000 C:\WINDOWS\System32\msvcp_win.dll
ModLoad: 00007ffc`33b90000 00007ffc`33c90000 C:\WINDOWS\System32\ucrtbase.dll
ModLoad: 00007ffc`35ac0000 00007ffc`36202000 C:\WINDOWS\System32\SHELL32.dll
(4ad0.33e0): Break instruction exception - code 80000003 (first chance)
ntdll!LdrpDoDebuggerBreak+0x30:
00007ffc`36520670 cc int 3
0:000> g
ModLoad: 00007ffc`355c0000 00007ffc`355f0000 C:\WINDOWS\System32\IMM32.DLL
ModLoad: 00007ffc`34ba0000 00007ffc`34c4e000 C:\WINDOWS\System32\shcore.dll
ModLoad: 00007ffc`35a20000 00007ffc`35abe000 C:\WINDOWS\System32\msvcrt.dll
ModLoad: 00007ffc`34840000 00007ffc`34b96000 C:\WINDOWS\System32\combase.dll
ModLoad: 00007ffc`35720000 00007ffc`3584b000 C:\WINDOWS\System32\RPCRT4.dll
ModLoad: 00007ffc`11d50000 00007ffc`11d68000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jli.dll
ModLoad: 00007ffc`224e0000 00007ffc`22590000 C:\WINDOWS\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_5.82.19041.488_none_4238de57f6b64d28\COMCTL32.dll
ModLoad: 00007ffc`22cb0000 00007ffc`22cc9000 C:\WINDOWS\SYSTEM32\VCRUNTIME140.dll
ModLoad: 00007ffc`34c50000 00007ffc`34cfc000 C:\WINDOWS\System32\ADVAPI32.dll
ModLoad: 00007ffc`35520000 00007ffc`355bc000 C:\WINDOWS\System32\sechost.dll
ModLoad: 00007ffc`10080000 00007ffc`10095000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\vcruntime140.dll
ModLoad: 00007ffb`f76b0000 00007ffb`f774b000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\msvcp140.dll
ModLoad: 00007ffb`a5030000 00007ffb`a5bbf000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\server\jvm.dll
ModLoad: 00007ffc`34630000 00007ffc`34638000 C:\WINDOWS\System32\PSAPI.DLL
ModLoad: 00007ffc`1ff10000 00007ffc`1ff19000 C:\WINDOWS\SYSTEM32\WSOCK32.dll
ModLoad: 00007ffc`32a70000 00007ffc`32a7a000 C:\WINDOWS\SYSTEM32\VERSION.dll
ModLoad: 00007ffc`261f0000 00007ffc`26217000 C:\WINDOWS\SYSTEM32\WINMM.dll
ModLoad: 00007ffc`35870000 00007ffc`358db000 C:\WINDOWS\System32\WS2_32.dll
ModLoad: 0000014c`22330000 0000014c`2239b000 C:\WINDOWS\System32\ws2_32.DLL
ModLoad: 00007ffc`32a30000 00007ffc`32a42000 C:\WINDOWS\SYSTEM32\kernel.appcore.dll
ModLoad: 00007ffc`2acf0000 00007ffc`2acfa000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jimage.dll
ModLoad: 00007ffc`22590000 00007ffc`22774000 C:\WINDOWS\SYSTEM32\DBGHELP.DLL
ModLoad: 00007ffc`21be0000 00007ffc`21c0c000 C:\WINDOWS\SYSTEM32\dbgcore.DLL
ModLoad: 00007ffc`34060000 00007ffc`340e0000 C:\WINDOWS\System32\bcryptPrimitives.dll
ModLoad: 00007ffc`09f50000 00007ffc`09f75000 C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\java.dll
(4ad0.30c4): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
0000014c`23890969 8b06 mov eax,dword ptr [rsi] ds:00000000`00000000=????????
0:004> g
(4ad0.30c4): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
*** WARNING: Unable to verify checksum for C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jimage.dll
00000000`00000000 ?? ???
0:004> g
ntdll!NtTerminateProcess+0x14:
00007ffc`364ecba4 c3 ret
对于Liberica,我可以通过添加以下行来实现:
runtime {
addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
addModules("javafx.base", "javafx.controls", "javafx.fxml") // <----
}
运行生成的exe将导致
Error: JavaFX runtime components are missing, and are required to run this application
我认为javafx模块不是放在模块路径上,而是放在类路径上(现在不支持AFAIK),这是一个问题。这似乎是所使用的运行时插件的一个问题(该插件表示它不支持模块化应用程序)
我可以通过添加
runtime {
...
launcher {
jvmArgs = ["--add-modules=javafx.base,javafx.controls,javafx.fxml"]
}
}
然后手动将javafxjar复制到app\mods
文件夹(我必须创建该文件夹)。查看生成的{app}.cfg
文件jpackage创建的文件,这就是启动器将用作模块路径的文件。我还从{app}.cfg
文件中删除了javafxjar不需要的app.classpath
条目。这是一个JDK15错误。使用JDK16的JPackage为我解决了这个问题。将这两个答案结合起来,等待一些东西更新,为我解决了这个问题
将Gradle升级到7.0-RC-1,在Gradle wrapper.properties
下载并使用Liberica JDK 16(@FlickIt)
在build.gradle(@Jorn Vernee)中使用Liberica的addModules()
fix
在Gradle中运行jpackage
现在可以生成可运行的JavaFX exe,而无需复制DLL
如果您的应用程序不仅仅依赖于JavaFX,请将#3更改为ALL-MODULE-PATH。它使打包的文件/应用程序更大,但允许其运行
runtime {
addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
addModules("ALL-MODULE-PATH")
}
您是否可以尝试查看手动运行带有生成的运行时映像的应用程序是否有效\build\jpackage\{app}\runtime\bin\java.exe-cp.\build\jpackage\{app}\app\{app}.jar io.mattw.sample.Main
问题可能只是在.exe启动程序中,在这种情况下,可能是您使用的wixtoolset版本有问题。似乎出现了一个无法找到或加载主类的错误。尝试将“--main class io.mattw.sample.main”
添加到运行时{addOptions()}
列表中,现在gradlew jpackage--info
命令出错,无法找到导出多个javafx模块的模块。我并不是要创建一个模块化的应用程序,只是一个简单的javafx应用程序和一个捆绑的运行时。我安装的WiX工具集似乎是3.11.2.4516。“错误是找不到导出多个javafx模块的模块”我不确定您在这里的意思,但AFAIK javafx模块必须放在模块路径上,并且由于您的应用程序是非模块化的,您可能缺少所需的--add modules
指令(但不确定利比里亚是如何处理的)。如果您可以将错误也包含在问题的主体中,这将非常有用。添加--main class
选项似乎无效,错误:未知选项:--main class io.mattw.sample.main
并删除它将使jpackage再次工作。我将包含尝试手动运行时映像的错误。它不能用于ind主类,因为它似乎无法找到javafx/app folder我看到javafx base,controls,fxml jarsEven with Liberica并添加了这一行,它似乎对我仍然不起作用。在尝试运行生成的exe时出现了相同的异常\u ACCESS\u违规。我遇到了其他问题,奇怪的是,它似乎可以工作,但并不理想。从{app}复制所有内容\运行时\bin
到`{app}`中,然后运行exe。啊,好吧,知道这一点很好。也许可以尝试将其缩小到特定的必需文件(我认为这是它需要的部分/所有.dll文件)。你也应该发布一个答案。似乎将文件{app}\runtime\bin\zip.dll
复制到{app}中就足够了\zip.dll
是的,我用调试器查看了它,它从我机器上路径上的另一个JDK加载zip.dll,而不是从绑定的运行时映像加载。清除路径会导致应用程序崩溃。看起来这个特定错误是由:(in 16)修复的是的,正如@Jorn已经指出的,它在这里被跟踪:并在16年修复了它。我想尝试一下,但Gradle不支持JDK16yet@MatthewWright通过使用新的工具链功能()可以使用JDK 16及以上,基本上是在JDK 15上运行Gradle,但使用JDK 16编译和运行代码。(尽管JDK 16目前存在一个bug,但有一个简单的解决方法:)@Matthewright您可以通过命令行运行JPackage,这就是我所做的。使用beryx jlink插件使用JDK 15.0.1创建运行时,然后从命令行使用JDK 16中的jpackager创建运行时,使用该运行时似乎是我发现的一项奇怪的工作。希望Gradle很快就会支持JDK16但是,在我的裸体示例中,当尝试用它迁移一个现有的JavaFX项目时,它不起作用。当尝试用\runtime\bin\java.exe-cp.\app\{app}.jar{main class}手动运行时
distributionUrl=https\://services.gradle.org/distributions/gradle-7.0-rc-1-bin.zip
runtime {
addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
addModules("javafx.base", "javafx.controls", "javafx.fxml", "javafx.graphics", "javafx.web")
}
runtime {
addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
addModules("ALL-MODULE-PATH")
}