这篇文章主要介绍“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+模块化项目打包的实现方法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。