记录问题:我们有个需求是根据
excel
模版导出一个excel
表。我们的项目是SpringBoot,所以理所当然的把这个模版文件放到了,resources
文件夹中。但是在导出文件的时候却遇到了invalid code lengths set
及Unexpected record signature: 0X9
的错误。
先说如何解决吧。两种方案任意一种即可解决该问题。
在
pom.xml
的中添加这一部分。
<build>
<resources>
<resource>
<directory>src/main/resourcesdirectory>
<includes>
<include>**/*include>
includes>
<excludes>
<exclude>**/*.xlsxexclude>
<exclude>**/*.xlsexclude>
<exclude>**/*.zipexclude>
<exclude>**/*.pdfexclude>
excludes>
<filtering>truefiltering>
resource>
<resource>
<directory>src/main/resourcesdirectory>
<includes>
<include>**/*.xlsxinclude>
<include>**/*.xlsinclude>
<include>**/*.zipinclude>
<include>**/*.pdfinclude>
includes>
<filtering>falsefiltering>
resource>
resources>
build>
使用
maven-resources-plugin
插件来帮我们在进行资源过滤
时,不要对指定扩展名的文件进行过滤。
<plugin>
<groupId>org.apache.maven.pluginsgroupId>
<artifactId>maven-resources-pluginartifactId>
<version>3.1.0version>
<configuration>
<nonFilteredFileExtensions>
<nonFilteredFileExtension>xlsxnonFilteredFileExtension>
<nonFilteredFileExtension>xlsnonFilteredFileExtension>
<nonFilteredFileExtension>zipnonFilteredFileExtension>
<nonFilteredFileExtension>pdfnonFilteredFileExtension>
nonFilteredFileExtensions>
configuration>
plugin>
资源过滤,他是要干什么?
占位符替换
。maven
在对构建项目的时候如何遇到文件中有${env}
这种格式的内容的时候,他就会在环境变量中或者项目变量中去寻找对应的值来进行替换。举例:像
db
这种配置通常为了安全,我们并不会直接将明文直接写在配置文件中,通常我们都是通过环境变量的方式来进行替换(虽然实际使用上并不是在打包环节进行替换,但是使用这种方式也可以达到目的)。
为什么会出现文件损坏等这种问题呢?
当
maven
,项目在构建并且我们开启了资源过滤的时候,maven
会去扫描所有资源文件中的内容,并且遇到占位符后会对其进行替换(这里其实还会对文件进行压缩等安全性的操作)。所以可能会对我们的一些资源文件造成损坏的问题,从而导致报错。通过在
pom.xml
中对资源文件进行一部分的排除过滤后,使得原文件可以跳过资源过滤从而保证文件的完整性。
遇到一个奇怪的问题。
我在Idea里面直接启动我的
SpringBoot
的时候,想使用这个资源过滤
来对一个文件进行占位符替换的时候,发现他不生效。
我在pom.xml
中添加了一个self.admin
的变量,想要通过这个变量来对文件中的一个占位符来进行替换。
pom.xml
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8project.reporting.outputEncoding>
<java.version>1.8java.version>
<resource.delimiter>${}resource.delimiter>
<self.admin>111self.admin>
properties>
原文件
${self.admin}
${pom.name}
直接启动SpringBoot
项目后生成的target
目录,发现并没有替换成功。
但是我使用mvn package
进行打包的时候,却发现可以正常替换成功。
这是为什么呢?我感觉这里其实也走了一部分
maven
的编译。因为我们在修改pom.xml
的一些plugin
配置的时候,他也会生效。这里我是个。有解决方案,那就是
强制让idea使用maven在对项目进行编译与运行
。在setting
中找到该选项Delegate build and run actions to Maven
并勾选他。
再次运行SpringBoot
项目,发现他成功替换了。
思考?
为什么
idea
识别到是maven
项目后不强制使用maven
来构建项目呢?我的想法
- 通常我们有一些插件并不需要在编译是使用,像有一些
jib-maven-plugin
构建docker
镜像。- 使用maevn编译可以会慢一些。
所有
idea
并没有默认勾选这个设置。