maven打包插件:maven-compiler-plugin、maven-dependency-plugin、maven-jar-plugin、maven-resources-plugin详解

本文详细介绍了如何使用Maven插件进行项目打包,包括maven-compiler-plugin、maven-jar-plugin、maven-dependency-plugin和maven-resources-plugin的配置与使用,帮助开发者在非Eclipse环境下顺利部署项目。

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

最近开发的产品,我们是有四五个maven模块,开发阶段一直是在eclipse中运行的,然后快发版的时候,需要把这些项目打成jar包,通过命令去启动,那首先就得把这些模块项目打包,或者拷贝一些资源文件等等。 
1.maven打包,首先在pom文件中加上build属性,和dependencies是同级的:

<build>
    <!--打包出来的文件名,可以不填写,有默认值-->
    <finalName>Test</finalName>
    <plugins>
        <!--这块写插件-->
    </plugins>
<build>

2.maven-compiler-plugin,编译插件,可能会用到的一些配置如下:

<plugin>  
       <groupId>org.apache.maven.plugins</groupId>  
       <artifactId>maven-compiler-plugin</artifactId>  
       <version>3.1</version>  
       <configuration>  
            <source>1.8</source>  
            <target>1.8</target>  
        </configuration>  
</plugin>

3.maven-jar-plugin,打jar包的插件,把整个maven工程打成jar包,可能会用到的一些配置如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <version>2.4</version>
    <configuration>
        <archive>
            <!-- 生成的jar中,包含pom.xml和pom.properties这两个文件 -->
            <addMavenDescriptor>true</addMavenDescriptor>
            <!-- 生成MANIFEST.MF的设置 -->
            <manifest>
                <!--这个属性特别关键,如果没有这个属性,有时候我们引用的包maven库
                下面可能会有多个包,并且只有一个是正确的,其余的可能是带时间戳的,
                此时会在classpath下面把那个带时间戳的给添加上去,然后我们
                在依赖打包的时候,打的是正确的,所以两头会对不上,报错。-->
                <useUniqueVersions>false</useUniqueVersions>
                <!-- 为依赖包添加路径, 这些路径会写在MANIFEST文件的Class-Path下 -->    
                <addClasspath>true</addClasspath>
                <!-- 这个jar所依赖的jar包添加classPath的时候的前缀,如果这个
                jar本身和依赖包在同一级目录,则不需要添加-->
                <classpathPrefix>lib/</classpathPrefix>
                <!-- jar启动入口类-->
                <mainClass>com.test.Test</mainClass>
            </manifest>
            <manifestEntries>
                <!-- 在Class-Path下添加配置文件的路径 -->
                <Class-Path>../config/</Class-Path>
                <!-- 假如这个项目可能要引入一些外部资源,但是你打包的时候并不想把
                这些资源文件打进包里面,这个时候你必须在这边额外指定一些这些资源
                文件的路径,这个位置指定的话,要根据你预期的这些位置去设置,我这边
                所有jar都在lib下,资源文件都在config下,lib和config是同级的 -->
                <!-- 同时还需要注意另外一个问题,假如你的pom文件里面配置了
                <scope>system</scope>,就是你依赖是你本地的资源,这个时候使用
                这个插件,classPath里面是不会添加,所以你得手动把这个依赖添加进
                这个地方,用空格隔开就行-->
            </manifestEntries>
        </archive>
        <!-- jar包的位置-->
        <outputDirectory>${project.build.directory}/lib</outputDirectory>
        <includes>
            <!-- 打jar包时,只打包class文件 -->
            <!-- 有时候可能需要一些其他文件,这边可以配置,包括剔除的文件等等-->
            <include>**/*.class</include>
        </includes>
    </configuration>
</plugin>

4.maven-dependency-plugin,用来拷贝项目所有依赖的插件,可能会用到的一些配置如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-dependency-plugin</artifactId>
    <executions>
        <execution>
            <id>copy-dependencies</id>
            <phase>package</phase>
            <goals>
                <goal>copy-dependencies</goal>
            </goals>
            <configuration>
                <!-- 拷贝项目依赖包到lib/目录下 -->
                <outputDirectory>${project.build.directory}/lib</outputDirectory>
                <!-- 间接依赖也拷贝 -->
                <excludeTransitive>false</excludeTransitive>
                <!-- 带上版本号 -->
                <stripVersion>false</stripVersion>
            </configuration>
        </execution>
    </executions>
</plugin>

5.maven-resources-plugin,用来拷贝项目中的一些资源文件,可能会用到的一些配置如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-resources-plugin</artifactId>
    <version>2.6</version>
    <executions>
        <!-- 一个execution就是一个目标输入位置,如果想把各种资源拆开放的话,就
        可以创建多个execution,一个资源文件可以被拷贝多份 -->
        <execution>
            <id>copy-resources</id>
            <phase>package</phase>
            <goals>
                <goal>copy-resources</goal>
            </goals>
            <configuration>
                <encoding>UTF-8</encoding>
                <!-- 资源文件的输出目录 -->
                <outputDirectory>{project.build.directory}/config</outputDirectory>
                <resources>
                    <!-- 资源文件的原始目录,有多个的话就多配几个 -->
                    <resource>
                        <!-- 原始目录 -->
                        <directory>src/main/resources</directory>
                        <!-- 是否使用过滤器,如果是的话,需要配置一下才行
                        这个后续再研究,这边没有使用到 -->
                        <filtering>true</filtering>
                        <!-- 包含哪些文件以及去除调哪些文件等等 -->
                        <includes>
                            <include>**/*.*</include>
                        </includes>
                        <excludes>
                            <exclude>**/*.json</exclude>
                        </excludes>
                    </resource>
                </resources>
            </configuration>
        </execution>
    </executions>
</plugin>

关于资源文件拷贝,注意一个小问题,平时用eclipse开发的话,默认的classPath其实就是target/classes,默认情况下,eclipse也会把一些在src/main/resources下的资源文件拷贝到这个目录下,但是如果你配了上述资源拷贝插件,只会按你配置的来,我配置上述插件是为了在非eclipse环境下运行的,但是这样影响到了eclipse的运行,所以呢,需要额外再配置一个execution,拷贝到classes目录下即可

以上就是这4个插件,后续如果还有其余插件或者这些插件中一些新内容,会及时添加。关于一些文件的输出目录,一定要根据自己的需求来,先明白自己想要什么,再去配置,或者两者互相迭代吧。

Maven 无法解析插件 `org.apache.maven.plugins:maven-compiler-plugin:3.14.0` 通常与网络连接、本地仓库损坏或插件版本不存在等问题相关。以下是一些常见的解决方法: ### 1. 检查 Maven 配置文件中的插件声明 确保 `pom.xml` 文件中正确声明了 `maven-compiler-plugin`,并且版本号是有效的。例如: ```xml <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.14.0</version> <configuration> <source>${jdk.version}</source> <target>${jdk.version}</target> </configuration> </plugin> ``` 如果使用的是较新的 JDK 版本,建议确认 `maven-compiler-plugin` 是否支持该 JDK,并根据需要调整版本号 [^2]。 ### 2. 清理 Maven 本地仓库 Maven 的本地存储库可能包含损坏的元数据文件或部分下载的插件包,导致插件无法正确解析。可以手动删除这些文件以强制 Maven 重新下载: - **默认路径**:`~/.m2/repository`(Linux/macOS)或 `C:\Users\YourUsername\.m2\repository`(Windows) - **操作步骤**: - 找到 `org/apache/maven/plugins/maven-compiler-plugin` 相关目录。 - 删除其中的 `.lastUpdated` 文件和任何 `.xml` 文件(如 `maven-metadata-local.xml`)。 - 运行 `mvn clean install` 或 `mvn dependency:resolve` 以触发重新下载 [^3]。 ### 3. 使用命令行更新插件 可以通过命令行显式更新插件依赖: ```bash mvn dependency:purge-local-repository mvn plugin:update-maven-plugin -Dplugin=org.apache.maven.plugins:maven-compiler-plugin ``` 这将清理本地仓库并尝试更新插件版本 [^3]。 ### 4. 更换 Maven 镜像源 如果网络连接不稳定,可以尝试更换 Maven 的镜像源。在 `settings.xml` 中添加阿里云或其他国内镜像配置: ```xml <mirror> <id>aliyun</id> <name>Aliyun Maven Mirror</name> <url>https://maven.aliyun.com/repository/public</url> <mirrorOf>central</mirrorOf> </mirror> ``` 这将加速插件和依赖的下载过程,并提高解析成功率 [^3]。 ### 5. 确认插件版本是否存在 有时指定的插件版本可能尚未发布或已被移除。访问 [Maven Central](https://search.maven.org/) 并搜索 `maven-compiler-plugin 3.14.0`,确认该版本是否可用。如果不可用,请选择一个已发布的稳定版本(如 `3.13.0` 或 `3.12.1`) [^1]。 ### 6. 强制使用特定插件版本 在 `settings.xml` 中可以全局定义插件管理器,以避免版本冲突: ```xml <pluginManagement> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.14.0</version> </plugin> </plugins> </pluginManagement> ``` 这有助于统一项目中使用的插件版本,减少解析错误的可能性 [^2]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值