Maven 资源插件:非过滤文件后缀配置及风险规避

<nonFilteredFileExtensions> 用于在 Maven 开启全局资源过滤时,豁免指定后缀的文件,不对其进行变量替换与编码转换,防止二进制文件损坏。

1. 核心原理

1.1. 资源过滤(Filtering)

当你在 pom.xml 中设置:

xml 复制代码
<resources>
  <resource>
    <directory>src/main/resources</directory>
    <filtering>true</filtering> <!-- 开启全局过滤 -->
  </resource>
</resources>

Maven 会在打包时,扫描所有文本文件(.properties/.xml/.yml 等),替换 ${xxx}占位符为实际值。

1.2. 风险:二进制文件被破坏

若对 .doc/.xls/.pdf/.jpg/.zip等二进制文件执行同样操作,会:

  • 误解析二进制内容为文本

  • 破坏文件结构、编码、校验和打包后文件打不开、损坏、体积异常

1.3. <nonFilteredFileExtensions> 的作用

全局开启 filtering=true 时,白名单豁免指定后缀:

xml 复制代码
<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-resources-plugin</artifactId>
  <configuration>
    <!-- 这些后缀的文件:只复制、不过滤、不替换、不改编码 -->
    <nonFilteredFileExtensions> 
      <nonFilteredFileExtension>doc</nonFilteredFileExtension>
      <nonFilteredFileExtension>ttc</nonFilteredFileExtension>
      <nonFilteredFileExtension>docx</nonFilteredFileExtension>
      <nonFilteredFileExtension>xls</nonFilteredFileExtension>
      <nonFilteredFileExtension>xlsx</nonFilteredFileExtension>
    </nonFilteredFileExtensions>
  </configuration>
</plugin>

只原样复制,不做任何文本处理

2. 常见需要豁免的后缀(建议补充)

  • 文档:doc, docx, xls, xlsx, ppt, pdf

  • 图片:jpg, png, gif, bmp, ico, svg

  • 压缩 / 二进制:zip, rar, 7z, tar, gz

  • 证书 / 密钥:crt, pem, p12, pfx, jks, keystore

  • 其他:exe, dll, so, jar, class

3. 与 <exclude> 的区别

  • <nonFilteredFileExtensions>:包含但不处理(复制到 target/classes,但不过滤)

  • <exclude>:完全排除(不复制到 target/classes)

4. 完整正确结构

xml 复制代码
  <build>
    <resources>
      <resource>
        <directory>src/main/java</directory>
        <excludes>
          <exclude>**/*.java</exclude>
        </excludes>
        <includes>
          <include>**/*.*</include>
        </includes>
      </resource>
      <resource>
        <directory>src/main/resources</directory>
        <includes>
          <include>**/*.*</include>
        </includes>
        <filtering>true</filtering>
      </resource>
    </resources>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-resources-plugin</artifactId>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.1</version>
        <configuration>
          <source>17</source>
          <target>17</target>
          <encoding>UTF-8</encoding>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>3.1.2</version>
        <configuration>
          <skip>true</skip>
        </configuration>
      </plugin>
    </plugins>
    <pluginManagement>
      <plugins>
        <plugin>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-maven-plugin</artifactId>
          <version>2.7.18</version>
          <executions>
            <execution>
              <goals>
                <goal>repackage</goal>
              </goals>
            </execution>
          </executions>
        </plugin>
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.3.1</version>
          <configuration>
            <encoding>UTF-8</encoding>
            <useDefaultDelimiters>true</useDefaultDelimiters>

            <nonFilteredFileExtensions>
              <nonFilteredFileExtension>doc</nonFilteredFileExtension>
              <nonFilteredFileExtension>ttc</nonFilteredFileExtension>
              <nonFilteredFileExtension>docx</nonFilteredFileExtension>
              <nonFilteredFileExtension>xls</nonFilteredFileExtension>
              <nonFilteredFileExtension>xlsx</nonFilteredFileExtension>
            </nonFilteredFileExtensions>
          </configuration>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
相关推荐
>no problem<20 小时前
基于cola5.0的基础设施层的多数据库切换方案思路
数据库·spring boot·mybatisplus·cola5.0·数据库迁移适配
心之伊始21 小时前
Java 后端接入大模型:从 Token、并发到推理成本的完整估算方法
java·spring boot·性能优化·大模型·llm
BlackTurn21 小时前
技术经理投标
java
YG亲测源码屋21 小时前
java配置环境变量、jdk环境变量配置、java环境变量设置方法
java·开发语言
MIUMIUKK21 小时前
从语法层面,看懂 Python 的特殊处
java·开发语言·python
hujinyuan201601 天前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
basketball6161 天前
C++ 高级编程:2. 基本线程池实现
java·开发语言·c++
MageGojo1 天前
天气 API 接入实战:基于 ApiZero 实现实时天气、分钟级降水和 15 天预报查询
java·后端·spring·api 接口接入·接口实战
自动跟随1 天前
UWB自动跟随技术全栈解析:从定位算法到“位控一体化“
java·网络·人工智能
喜欢打篮球的普通人1 天前
LLVM 后端流程与关键数据结构:从 IR 到机器码的入门笔记
java·数据结构·笔记