这篇文章主要介绍“JDK11+模块化项目打包的实现方法”,在日常操作中,相信很多人在JDK11+模块化项目打包的实现方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JDK11+模块化项目打包的实现方法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
windows10
STS: 4.7.2.RELEASE(eclipse2.3.200.v20200604-0540)
OpenJDK11.0.9
MAVEN3.6.3
<groupId>com.study</groupId>
<artifactId>jfx-demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
编译配置
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.2</version>
<configuration>
<source>11</source>
<target>11</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
项目目录结构如下:
启动类App.java
package com.study.jfx;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class App extends Application {
public static void main(String[] args) {
launch(args);
}
@Override
public void start(@SuppressWarnings("exports") Stage primaryStage) throws Exception {
primaryStage.setTitle("wxCert");
primaryStage.show();
Button btn = new Button();
btn.setText("Say 'Hello World'");
btn.setOnAction(event -> {
System.out.println("Hello World!");
});
StackPane root = new StackPane();
root.getChildren().add(btn);
Scene scene = new Scene(root, 300, 250);
primaryStage.setScene(scene);
}
}
模块化文件
module com.study.jfx {
requires javafx.controls;
opens com.study.jfx to javafx.controls;
exports com.study.jfx;
}
模块化配置的说明:
声明模块化项目的名称。
声明依赖的模块,不用重复声明javafx.base和javafx.graphics。
给javafx.controls开放本项目的类。
导出本项目类,启动项目需要。
maven的依赖库配置
<dependencies>
<dependency>
<groupId>org.openjfx</groupId>
<artifactId>javafx-controls</artifactId>
<version>11.0.2</version>
</dependency>
</dependencies>
maven插件配置一:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>3.1.2</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<configuration>
<outputDirectory>${basedir}/target/lib</outputDirectory>
<overWriteReleases>false</overWriteReleases>
<overWriteSnapshots>false</overWriteSnapshots>
<overWriteIfNewer>true</overWriteIfNewer>
</configuration>
<goals>
<goal>copy-dependencies</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<version>3.3.0</version>
<configuration>
<appendAssemblyId>false</appendAssemblyId>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<mainClass>com.study.jfx.App</mainClass>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
使用插件配置一,执行maven命令:clean package
,会在target文件夹下生成如下目录:
cmd命令启动项目:
java --module-path lib --add-modules=javafx.controls,javafx.base,javafx.graphics -jar jfx-demo-0.0.1-SNAPSHOT.jar
maven插件配置二:
<plugin>
<groupId>org.openjfx</groupId>
<artifactId>javafx-maven-plugin</artifactId>
<version>0.0.5</version>
<configuration>
<mainClass>com.study.jfx.App</mainClass>
</configuration>
</plugin>
使用JavaFx提供的创建,执行maven命令clean javafx:jlink
可以定制JRE。 当然,使用JDK自身提供的jdeps+jlink来定制更好。
这一配置可以直接通过执行main方法启动项目,不需要依赖javafx-maven-plugin的命令clean javafx:run
来启动项目。
先用OpenJDK15使用此配置打包也成功了。
不知道为什么我在一个IDE里面使用第二个JavaFx环境(单独的工作空间)会出JVM依赖库不匹配的异常。
插件版本降低也能成功打包运行。
到此,关于“JDK11+模块化项目打包的实现方法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4029901/blog/4996678