Maven 多模块打包

本文详细介绍了Maven项目中用于编译源代码、导出模块和依赖的插件配置。包括使用maven-compiler-plugin设置Java编译源和目标版本为11,排除module-info.java的编译;使用maven-antrun-plugin复制模块A和B的目标文件到指定目录;以及使用maven-dependency-plugin将特定依赖项复制到libs目录。

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

<build>
        <plugins>
            <!--编译-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>11</source>
                    <target>11</target>
                </configuration>
                <executions>
                    <execution>
                        <configuration>
                            <excludes>
                                <exclude>module-info.java</exclude>
                            </excludes>
                        </configuration>
                    </execution>
                </executions>
            </plugin>

            <!-- 导出所有模块 -->
            <plugin>
                <artifactId>maven-antrun-plugin</artifactId>
                <executions>
                    <execution>
                        <id>copy</id>
                        <phase>package</phase>
                        <configuration>
                            <tasks>
                                <copy todir="${user.dir}/jars">
                                    <fileset dir="./moudle_a/target">
                                        <include name="*.jar"/>
                                    </fileset>
                                    <fileset dir="./../moudle_b/target">
                                        <include name="*.jar"/>
                                    </fileset>
                                </copy>
                            </tasks>
                        </configuration>
                        <goals>
                            <goal>run</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

            <!-- 导出所有依赖 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <executions>
                    <execution>
                        <id>copy-artifact</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy</goal>
                        </goals>
                        <configuration>
                            <artifactItems>
                                <artifactItem>
                                    <groupId>com.alibaba</groupId>
                                    <artifactId>fastjson</artifactId>
                                    <version>1.2.47</version>
                                    <type>jar</type>
                                    <overWrite>false</overWrite>
                                </artifactItem>
                                <artifactItem>
                                    <groupId>com.belerweb</groupId>
                                    <artifactId>pinyin4j</artifactId>
                                    <version>2.5.1</version>
                                    <type>jar</type>
                                    <overWrite>false</overWrite>
                                </artifactItem>
                            </artifactItems>
                            <outputDirectory>${user.dir}/libs</outputDirectory>
                            <overWriteReleases>false</overWriteReleases>
                            <overWriteSnapshots>true</overWriteSnapshots>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

 

### 将Maven多模块项目打包成单个JAR文件的方法 对于Maven多模块项目,如果希望将其最终打包为一个单独的JAR文件,则可以选择使用`maven-shade-plugin`或`maven-assembly-plugin`来实现这一目标。以下是两种方法的具体说明: #### 使用 `maven-shade-plugin` `maven-shade-plugin` 是一种常用的工具,能够将当前项目的类以及其所有的依赖项合并到一个单一的JAR文件中[^1]。它特别适合于需要创建可运行的fat JAR(也称为uber JAR)的情况。 ##### 配置示例 在父POM或子模块的POM文件中添加如下配置: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.2.4</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <!-- 添加Main-Class属性 --> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>com.example.MainApp</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 上述配置会将所有依赖项嵌入到生成的JAR文件中,并设置启动类以便可以直接通过命令行运行该JAR文件[^2]。 #### 使用 `maven-assembly-plugin` 另一种方式是利用 `maven-assembly-plugin` 来完成同样的任务。此插件允许更灵活地定义打包的内容和结构,支持多种预定义模板或者自定义描述符文件[^3]。 ##### 配置示例 同样,在对应的 POM 文件里加入以下片段即可: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-assembly-plugin</artifactId> <version>3.3.0</version> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> <archive> <manifest> <mainClass>com.example.MainApp</mainClass> </manifest> </archive> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>single</goal> </goals> </execution> </executions> </plugin> </plugins> </build> ``` 这段代码的作用类似于 `maven-shade-plugin` 的功能,但它提供了更多的选项来自定义输出格式。 无论采用哪种方案,都需要确保指定正确的入口点 (`Main-Class`) 并处理好可能存在的资源冲突等问题。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风铃峰顶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值