将Java项目打包为可执行JAR 文件的四种方法

 更新时间:2025年08月18日 11:16:54   作者:xienda  
本文主要介绍了Java项目打包为可执行JAR的四种方法,包括IDE配置、Maven/Gradle插件、手动创建及依赖管理,具有一定的参考价值,感兴趣的可以了解一下

我将详细介绍将 Java 项目打包为可执行 JAR 文件的完整流程,包括使用 IDE 和命令行两种方法。

方法一:使用 IntelliJ IDEA 打包

步骤 1:配置项目结构

  • 打开项目
  • 点击 File > Project Structure
  • 在 Project Settings 中选择 Artifacts
  • 点击 + 号 > JAR > From modules with dependencies

步骤 2:配置主类

  • 在 "Main Class" 字段选择主类:例如:com.example.demo.DesktopFileSearch
  • 确保选择 "extract to the target JAR" 选项
  • 点击 OK

步骤 3:构建 JAR 文件

  • 点击 Build > Build Artifacts
  • 选择您的 artifact > Build
  • 生成的 JAR 文件将位于 out/artifacts/ 目录下

方法二:使用 Maven 打包

步骤 1:添加 Maven 插件

在 pom.xml 中添加以下插件配置:

<build>
    <plugins>
        <!-- 编译插件 -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.1</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>
        
        <!-- 创建可执行 JAR 的插件 -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>3.2.0</version>
            <configuration>
                <archive>
                    <manifest>
                        <addClasspath>true</addClasspath>
                        <mainClass>com.example.demo.DesktopFileSearch</mainClass>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
        
        <!-- 包含依赖的插件(可选) -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>3.3.0</version>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>com.example.demo.DesktopFileSearch</mainClass>
                    </manifest>
                </archive>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

步骤 2:执行打包命令

在项目根目录(包含 pom.xml 的目录)打开命令行,执行:

mvn clean package

步骤 3:获取 JAR 文件

  • 生成的 JAR 文件位于 target/ 目录
  • 如果使用了 assembly 插件,会生成两个文件:
    • your-project-name.jar - 不含依赖
    • your-project-name-jar-with-dependencies.jar - 包含所有依赖

方法三:使用 Gradle 打包

步骤 1:配置 build.gradle

在 build.gradle 文件中添加:

plugins {
    id 'java'
    id 'application'
}

application {
    mainClassName = 'com.example.demo.DesktopFileSearch'
}

jar {
    manifest {
        attributes 'Main-Class': 'com.example.demo.DesktopFileSearch'
    }
    
    // 包含所有依赖(可选)
    from {
        configurations.runtimeClasspath.collect { it.isDirectory() ? it : zipTree(it) }
    }
}

步骤 2:执行打包命令

在项目根目录执行:

gradle clean build

步骤 3:获取 JAR 文件

生成的 JAR 文件位于 build/libs/ 目录

方法四:手动创建 JAR(不使用构建工具)

步骤 1:编译 Java 文件

javac -d target/classes src/main/java/com/example/demo/*.java

步骤 2:创建清单文件

创建 META-INF/MANIFEST.MF 文件:

Manifest-Version: 1.0
Main-Class: com.example.demo.DesktopFileSearch
Class-Path: .

步骤 3:打包为 JAR

jar cfm target/your-app.jar META-INF/MANIFEST.MF -C target/classes .

测试 JAR 文件

运行 JAR 文件以确保正确打包:

java -jar your-app.jar

常见问题解决

问题:运行 JAR 时出现 "No main manifest attribute"

解决方案

  • 确保 MANIFEST.MF 文件包含正确的 Main-Class 属性
  • 使用 jar tf your-app.jar 检查清单文件是否正确包含
  • 如果使用 Maven/Gradle,确保插件配置正确

问题:缺少依赖项

解决方案

  1. 使用包含依赖的打包方式(如 maven-assembly-plugin)

  2. 将所有依赖 JAR 放在同一目录,使用 -cp 指定类路径:

    java -cp "your-app.jar:libs/*" com.example.demo.DesktopFileSearch

问题:资源文件未包含

解决方案

  1. 确保资源文件位于正确位置(如 src/main/resources)

  2. 在构建配置中包含资源目录:

    java -cp "your-app.jar:libs/*" com.example.demo.DesktopFileSearch

最佳实践

版本控制:在 JAR 文件名中包含版本号

依赖管理

  • 对于简单项目,使用包含依赖的单一 JAR
  • 对于大型项目,使用 lib 目录存放依赖

签名验证:使用 jarsigner 对 JAR 进行签名

jarsigner -keystore mykeystore.jks -storepass password -keypass password your-app.jar mykey

瘦身打包:使用 ProGuard 或其它工具减小 JAR 大小

跨平台测试:在不同操作系统上测试 JAR 文件

总结打包 Java 应用程序为 JAR 文件是分发和部署的关键步骤。选择适合您项目的打包方法:

  • 简单项目:使用 IDE 内置的导出功能
  • 标准项目:使用 Maven 或 Gradle 构建
  • 需要依赖管理:使用包含依赖的打包方式
  • 特殊需求:手动创建 JAR 文件

完成 JAR 打包后,您可以进一步使用 Launch4j 或 jpackage 工具将其转换为 EXE 文件,创建完整的 Windows 安装程序。

到此这篇关于将Java项目打包为可执行JAR 文件的文章就介绍到这了,更多相关java打包jar命令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java延迟队列原理与用法实例详解

    Java延迟队列原理与用法实例详解

    这篇文章主要介绍了Java延迟队列原理与用法,结合实例形式详细分析了延迟队列的概念、原理、功能及具体使用方法,需要的朋友可以参考下
    2018-09-09
  • Java的设计模式之代理模式使用详解

    Java的设计模式之代理模式使用详解

    这篇文章主要介绍了Java的设计模式之代理模式使用详解,代理模式是23种设计模式之一,它关心的主要是过程,而不是结果,代理模式主要提供了对目标对象的间接访问方式,即通过代理对象来访问目标对象,需要的朋友可以参考下
    2024-01-01
  • SpringBoot参数校验,消除if else方式

    SpringBoot参数校验,消除if else方式

    文章介绍了使用JSR303和Spring Boot中的spring-boot-starter-validation进行数据验证的方法,包括注解使用、分组验证、嵌套对象校验、快速失败配置以及自定义校验规则等内容
    2026-04-04
  • springboot中如何配置LocalDateTime JSON返回时间戳

    springboot中如何配置LocalDateTime JSON返回时间戳

    这篇文章主要介绍了springboot中如何配置LocalDateTime JSON返回时间戳问题。具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • springboot自定义starter示例代码

    springboot自定义starter示例代码

    SpringBoot自定义Starter项目的命名建议遵循xxx-spring-boot-starter格式,以避免与官方或第三方Starter产生冲突,核心规范包括自动装配文件的配置,旨在通过spring.factories或spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
    2024-11-11
  • IDEA连接mysql数据库报错的解决方法

    IDEA连接mysql数据库报错的解决方法

    这篇文章主要介绍了IDEA连接mysql数据库报错的解决方法,文中有非常详细的图文示例,对出现Server returns invalid timezone. Go to ‘Advanced‘ tab and set ‘serverTimezone‘ prope报错的小伙伴们很有帮助哟,需要的朋友可以参考下
    2021-05-05
  • 浅谈sql_@SelectProvider及使用注意说明

    浅谈sql_@SelectProvider及使用注意说明

    这篇文章主要介绍了sql_@SelectProvider及使用注意说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 图文详解java反射机制及常用应用场景

    图文详解java反射机制及常用应用场景

    这篇文章主要为大家介绍了图文详解java反射机制及常用应用场景,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • java Thread 多线程

    java Thread 多线程

    本篇文章小编为大家介绍,java Thread 多线程。需要的朋友参考下
    2013-04-04
  • mybatis实现增删改查_动力节点Java学院整理

    mybatis实现增删改查_动力节点Java学院整理

    本文通过实例代码给大家介绍了mybatis实现增删改查功能,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-09-09

最新评论