Maven:打包pom里面配置exclude 排除掉环境相关的配置文件。

本文介绍了在Maven项目中如何灵活配置资源文件的方法,包括使用include与exclude来精确控制哪些文件应该被包含或排除在构建过程中。通过具体示例展示了如何只过滤特定的配置文件,同时保持其他文件不变。

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

方式

  1. 打包时,指定环境参数把环境的配置文件复制过去
  2. 不打包所有的环境相关的配置文件,直接由运维的人维护

可以在上传war包前把配置给改了,用rar工具改里面的配置,但每次都改太麻烦;第一次上面放有这个配置文件,后面打包时排除掉就可以了,上面的解压后就不会覆盖了;我们公司就用2,后面打包时排除掉就可以了,上面的解压后就不会覆盖了。

关于Maven resource配制中include与exclude的关系

<include>与<exclude>是用来圈定和排除某一文件目录下的文件是否是工程资源的。如果<include>与<exclude>划定的范围存在冲突时,以<exclude>划定的范围为准。大多数情况下,人们使用<include>和<exclude>是为了配合<filtering>实现过滤特定文件的需要。例如,在一个工程中,src/main/resources目录下都是工程的资源文件,并不需要<include>和<exclude>再进行划定。但如果我们需要对且仅对其中的jdbc.properties和mail.properties两个文件进行过滤的话,则需要借助<include>和<exclude>进行如下的配置:

<resources>
        <!-- Filter jdbc.properties & mail.properties. NOTE: We don't filter applicationContext-infrastructure.xml, 
            let it go with spring's resource process mechanism. -->
        <resource>
            <directory>src/main/resources</directory>
            <filtering>true</filtering>
            <includes>
                <include>jdbc.properties</include>
                <include>mail.properties</include>
            </includes>
        </resource>
        <!-- Include other files as resources files. -->
        <resource>
            <directory>src/main/resources</directory>
            <filtering>false</filtering>
            <excludes>
                <exclude>jdbc.properties</exclude>
                <exclude>mail.properties</exclude>
            </excludes>
        </resource>
    </resources>

其中第一段<resource>配置声明:在src/main/resources目录下,仅jdbc.properties和mail.properties两个文件是资源文件,然后,这两个文件需要被过滤。而第二段<resource>配置声明:同样在src/main/resources目录下,除jdbc.properties和mail.properties两个文件外的其他文件也是资源文件,但是它们不会被过滤。

转载:https://www.cnblogs.com/zdz8207/p/java-maven-pom-resource-exclude.html

### 关于 Maven Project 中 `pom.xml` 配置文件详情 #### POM 文件结构概述 POM (Project Object Model) 是 Maven 的核心概念之一。它是一个 XML 文件,包含了构建项目的几乎全部配置信息。通过定义依赖关系、插件和其他设置来控制如何编译和打包项目[^1]。 #### 基本元素解释 - **project**: 根节点,包含整个文档的内容。 - **modelVersion**: 定义模型版本号,默认为4.0.0,表示当前使用的POM/XSD模式版本。 - **groupId**: 组织或公司顶级域名的反写形式加上项目名称的一部分,用于区分不同组织下的 artifactId。 - **artifactId**: 构件ID,在同一个 groupId 下唯一标识一个构件。 - **version**: 当前构件的具体版本号。 - **packaging**: 打包方式,可以是 jar, war 或 pom 等不同类型,默认为jar[^2]。 ```xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <!-- 项目坐标 --> <groupId>com.example</groupId> <artifactId>example-project</artifactId> <version>1.0-SNAPSHOT</version> <!-- 打包类型 --> <packaging>war</packaging> </project> ``` #### 插件配置实例 对于 Web 应用程序来说,通常会涉及到 WAR 文件的创建过程中的特定需求处理,比如排除某些资源不被打入最终产物中: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> <version>3.3.1</version> <configuration> <webResources> <resource> <directory>${basedir}/src/main/webapp</directory> <excludes> <exclude>*.txt</exclude> </excludes> </resource> </webResources> </configuration> </plugin> </plugins> </build> ``` 上述代码展示了如何利用 maven-war-plugin 来定制化 web 资源管理逻辑,特别是当需要从默认路径下筛选出不需要参与打包操作的目标时非常有用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值