JavaFX打包:NoClassDefFoundError

tan*_*rli 5 java javafx maven

我使用maven和OpenJDK 1.8打包了JavaFX应用程序,其中的相关部分来自我的pom.xml:

<plugin>
    <artifactId>maven-assembly-plugin</artifactId>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>single</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <archive>
            <manifest>
                <addClasspath>true</addClasspath>
                <mainClass>ui.Main</mainClass>
            </manifest>
        </archive>
        <descriptorRefs>
            <descriptorRef>jar-with-dependencies</descriptorRef>
        </descriptorRefs>
    </configuration>
</plugin>
Run Code Online (Sandbox Code Playgroud)

现在重要的是,这曾经起作用。我知道这一点是因为我在包装最终起作用的地方专门进行了git commit。经过大约一天的时间,并进行了多次这样的构建(我不知道更改了什么),由于以下错误,我无法再启动jar:

$ java -jar target/app.jar
Error: Could not find or load main class ui.Main Caused by:
java.lang.NoClassDefFoundError: javafx/application/Application
Run Code Online (Sandbox Code Playgroud)

当我查看Jar的内容时,可以看到除JavaFX类之外,所有依赖项都被明确包含在内。

我尝试过的

  • javapackager
  • 修补javafx-maven-plugin
  • 明确地将JavaFX作为依赖项添加到我的pom.xml中,希望程序集插件可以为我打包

以上都不成功。我能够启动我的应用程序的唯一方法是直接从IDE,这似乎意味着JavaFX的库的仍然可用我的系统上。

关于如何再次运行它的任何想法?

tan*_*rli 4

简短回答

我使用 openJDK 11 运行我的 jar,其中不包含 JavaFX,同时使用 openJDK 8 构建它。案例已结。

调查结果、细节和原因

由于我的 IDE 能够毫无问题地运行我的代码,因此我认为该问题特定于我的配置/机器。事实证明 Canonical/Ubuntu 决定了

[对于] Bionic [...]在 2018 年 9 月/10 月将 main 中的默认 JRE/JDK作为 SRU 移至 OpenJDK 11。询问Ubuntu

并且,正如另一个 SO 线程所指出的:

JavaFX 11不再 是 JDK 的一部分StackOverflow

(这还包括如何使用 JDK 11 修复此问题的说明)

最后,正如墨菲定律所规定的那样,我在 10 月 4 日设置了项目打包,并决定在 10 月 8 日通过 apt 安装 eclipse,其中包括openjdk-11-jdk:amd64(这已记录在有用的/var/log/apt/history.log)。

更新了我/etc/alternatives/java指向 v11。由于我在没有明确指定 java 二进制文件的情况下运行了 jar,因此它崩溃了。

跑步

/usr/lib/jvm/java-8-openjdk-amd64/bin/java -jar target/app.jar
Run Code Online (Sandbox Code Playgroud)

快速测试按预期工作。现在我只需要将我的项目升级到 openJDK 11,否则始终使用特定的 JDK 8 运行我的应用程序。