Maven打包jar及依赖

本文介绍如何使用Maven进行jar包的构建与管理,包括依赖本地jar包、将依赖的jar包整合进新生成的jar、将jar包添加到本地仓库及指定Java版本等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.依赖本地jar包:system scope

<dependencies>里添加
<dependency>
    <groupId>norma-log-parser</groupId>
    <artifactId>norma-log-parser</artifactId>
    <version>1.0.0-SNAPSHOT</version>
    <type>jar</type>
    <scope>system</scope>
    <systemPath>${project.basedir}/libs/norma-log-parser-1.0.0-SNAPSHOT.jar</systemPath>
</dependency>

2.把依赖jar包添加到新生成的jar的libs目录里

<build>里添加
<resources>
    <resource>
        <targetPath>libs</targetPath>
        <directory>libs</directory>
        <includes>
            <include>**/norma-log-parser-1.0.0-SNAPSHOT.jar</include>
        </includes>
    </resource>
</resources>

3. 把所有依赖包打进新生成的jar,在<build>里添加

<plugins>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <executions>
            <execution>
                <id>make-assembly</id>
                <phase>package</phase>
                <goals>
                    <goal>shade</goal>
                </goals>
                <configuration>
                    <finalName>norma-log-parser_contain-with-dependencies</finalName>
                </configuration>
            </execution>
        </executions>
    </plugin>
    <!--<plugin>-->
    <!--<artifactId>maven-assembly-plugin</artifactId>-->
    <!--<configuration>-->
    <!--<descriptorRefs>-->
    <!--<descriptorRef>jar-with-dependencies</descriptorRef>-->
    <!--</descriptorRefs>-->
    <!--</configuration>-->
    <!--</plugin>-->
</plugins>

4.jar包添加到本地仓库:使用依赖的时候可以去除system scope

mvn install:install-file -Dfile=norma-log-parser-1.0.0-SNAPSHOT.jar -DgroupId=norma-log-parser -DartifactId=
norma-log-parser -Dversion=1.0 -Dpackaging=jar

5.指定java使用版本:

<properties>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
</properties>


生成添加依赖包的jar比较好的方式:

1.如果依赖本地jar,先把jar添加到本地仓库,如上4中。

2.把依赖的包打入新jar中,如上3中。(不需要2中添加resource)

编译出来的jar包可以在其他项目中引用。

Maven 项目打包过程中,将依赖JAR 包与项目自身的代码分离是一种常见的优化手段,尤其适用于分布式系统或需要频繁更新和部署的应用。这种方式可以显著减少每次部署时的数据传输量,并提高部署效率。 ### 实现方式 #### 1. 使用 `maven-jar-plugin` 和 `maven-dependency-plugin` 通过配置 `maven-jar-plugin` 来生成仅包含项目编译后代码的 JAR 文件,同时使用 `maven-dependency-plugin` 将所有依赖复制到指定目录(如 `lib/`),从而实现代码与依赖的分离。 ```xml <build> <plugins> <!-- 配置 maven-jar-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> <classpathPrefix>lib/</classpathPrefix> <mainClass>com.example.MainClass</mainClass> </manifest> </archive> </configuration> </plugin> <!-- 配置 maven-dependency-plugin 将依赖复制到 lib 目录 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>3.1.0</version> <executions> <execution> <id>copy-dependencies</id> <phase>package</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <outputDirectory>${project.build.directory}/lib</outputDirectory> <overWriteReleases>false</overWriteReleases> <overWriteSnapshots>false</overWriteSnapshots> <overWriteIfNewer>true</overWriteIfNewer> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 上述配置中,`maven-jar-plugin` 会生成一个仅包含项目代码的 JAR,并且在 MANIFEST.MF 中添加 `Class-Path` 指向 `lib/` 目录下的依赖 JAR 包[^2]。而 `maven-dependency-plugin` 则负责将所有的依赖文件复制到 `target/lib` 目录下,便于后续部署时一起打包[^3]。 #### 2. 使用 `spring-boot-maven-plugin`(适用于 Spring Boot 项目) 对于 Spring Boot 项目,可以通过 `spring-boot-maven-plugin` 的 `repackage` 功能来控制是否将依赖打包进最终的 JAR 文件中。如果希望将依赖分离出来,可以关闭 `repackage` 并手动管理依赖包: ```xml <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>${spring-boot.version}</version> <configuration> <mainClass>com.example.MainClass</mainClass> <includeSystemScope>true</includeSystemScope> </configuration> <executions> <execution> <goals> <goal>repackage</goal> </goals> <configuration> <skip>true</skip> <!-- 关闭 repackage 以避免依赖打包进主 JAR --> </configuration> </execution> </executions> </plugin> ``` 此外,仍然可以结合 `maven-dependency-plugin` 来将依赖复制到指定目录,以便进行分发和部署[^3]。 ### 跳过测试以加快构建速度 在某些情况下,为了加快构建过程,特别是在 CI/CD 流程中,可以选择跳过单元测试: ```xml <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>2.22.1</version> <configuration> <skipTests>true</skipTests> </configuration> </plugin> ``` 这样可以在打包时不执行测试用例,从而节省时间[^4]。 ### 验证打包结果 完成上述配置后,执行以下命令进行打包: ```bash mvn clean package ``` 打包完成后,进入 `target/` 目录查看生成的 JAR 文件以及 `lib/` 目录下的依赖包。解压生成的 JAR 文件并检查 `META-INF/MANIFEST.MF` 文件中的 `Class-Path` 是否正确指向了 `lib/` 目录下的各个依赖 JAR 包[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值