文章目录
- 开始打包
- 打开文件结构
- 选中 Artifacts,点 “+”
- from modules with dependencies
- 选择想打包的 module
- 选择 Server Module 中的 main 函数所在的文件
- 确认即可
- 对 Client Module 重复以上操作
- 在左侧的栏中,可以看到我们已经初步完成了 jar 包的构建
- 完成上述步骤,src 中会出现 META-INF 这个文件夹
- 将刚才预备好的 jar Artifacts build 成 真正的 jar 文件
- 选择 All Artifacts 进行 Build
- 完成后,out 包里面会有两个 _jar 文件,里面包含了我们的 .jar 文件
- 到此为止,我们就完成了所有的打包步骤。
- 注意
之前上课老师布置了分布式系统的作业,让我们写一个分布式系统,实现客户端和服务端的通信工作,然后让我们吧可执行的代码封装成 客户端.jar 和 服务端.jar 由于两个包中都使用了很多依赖,所以在这篇文章中会详细介绍如何把可执行的程序和相关依赖打到一个包里。
文档结构如下
开始打包
打开文件结构
- 通过图中指示的地方打开
- 或者通过
File -> Project structure
选中 Artifacts,点 “+”
from modules with dependencies
- 把执行文件和依赖打包到一起
选择想打包的 module
- 因为在本文中是将 Server 和 Client 分别打包,因此我们先选择 Server
选择 Server Module 中的 main 函数所在的文件
- 这里是选择执行文件作为程序的入口。
确认即可
对 Client Module 重复以上操作
在左侧的栏中,可以看到我们已经初步完成了 jar 包的构建
完成上述步骤,src 中会出现 META-INF 这个文件夹
- 如果你想重复执行打包操作,或者是在打包的过程中报错。就把
META-INF
这个文件夹删掉再来一次。 - 因为
MEAT-INF
文件夹的存在是构建 jar 包的关键。如果你要重新打包,一定要把这个文件夹删掉再来 out
文件夹是最终输出 jar 包的地方,如果你想重来,这个包也删掉。或者不删,重新打包时他也会自动覆盖。
将刚才预备好的 jar Artifacts build 成 真正的 jar 文件
选择 All Artifacts 进行 Build
- 因为我们之前的
Artifacts
已经准备好了Client.jar
和Server.jar
的Artifacts
,因此我们同时把这两个jar
build
出来就行了。 - 当然你也可以选择一个一个的
build
。 方法就是选中下面的Server.jar
或者Client.jar
点build
。
完成后,out 包里面会有两个 _jar 文件,里面包含了我们的 .jar 文件
到此为止,我们就完成了所有的打包步骤。
- 这两个
.jar
文件可以 单独执行,因为里面包含了所有的依赖文件。
注意
- 如果报这个错误;果断把 META-INF 删了,然后把所有步骤重新执行一遍
- 最好也把
out
文件夹全删了,无所谓,不会有问题的。