【SpringBoot Resources目录下word, excel文件损坏异常】

SpringBoot Resources目录下word, excel文件损坏异常

一、错误原因

org.apache.poi.openxml4j.exceptions.NotOfficeXmlFileException: No valid entries or document

二、排查问题

  • SpringBoot resources 下新增word,excel模板文件用于下载
  • build编译后target文件下对应word,excel显示文件已损坏
  • SpringBoot会对resources下文件进行压缩,导致word,excel格式异常

三、解决问题

 <plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-compiler-plugin</artifactId>
     <version>3.8.1</version>
     <configuration>
         <source>1.8</source>
         <target>1.8</target>
         <encoding>UTF-8</encoding>
     </configuration>
 </plugin>
 <plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-resources-plugin</artifactId>
     <configuration>
         <nonFilteredFileExtensions>
             <nonFilteredFileExtension>xlsx</nonFilteredFileExtension>
             <nonFilteredFileExtension>docx</nonFilteredFileExtension>
         </nonFilteredFileExtensions>
     </configuration>
 </plugin>

通过使用maven-resources-plugin下的标签nonFilteredFileExtensions,让xlsx和word文件不再被压缩编译,避免office文件格式异常。

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot 项目可以使用如下 9 种方式来读取 resources 目录下的文件: 1. 使用 ClassLoader.getResourceAsStream() 方法: ``` InputStream inputStream = getClass().getClassLoader().getResourceAsStream("file.txt"); ``` 2. 使用 ClassLoader.getSystemResourceAsStream() 方法: ``` InputStream inputStream = ClassLoader.getSystemResourceAsStream("file.txt"); ``` 3. 使用 Class.getClassLoader().getResourceAsStream() 方法: ``` InputStream inputStream = Class.class.getClassLoader().getResourceAsStream("file.txt"); ``` 4. 使用 Thread.currentThread().getContextClassLoader().getResourceAsStream() 方法: ``` InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("file.txt"); ``` 5. 使用 Class.getResourceAsStream() 方法: ``` InputStream inputStream = getClass().getResourceAsStream("/file.txt"); ``` 6. 使用 Class.getResourceAsStream() 方法(不以'/'开头): ``` InputStream inputStream = getClass().getResourceAsStream("file.txt"); ``` 7. 使用 ClassLoader.getResource() 方法: ``` URL url = getClass().getClassLoader().getResource("file.txt"); ``` 8. 使用 ClassLoader.getSystemResource() 方法: ``` URL url = ClassLoader.getSystemResource("file.txt"); ``` 9. 使用 Class.class.getResource() 方法: ``` URL url = Class.class.getResource("/file.txt"); ``` 注意:上述代码中的 `file.txt` 是 resources 目录下的文件名字,可以根据实际情况替换成其他文件名。 ### 回答2: Spring Boot项目可以使用以下9种方式来读取resources目录下的文件: 1. 使用ClassLoader.getResourceAsStream()方法: ```java InputStream inputStream = getClass().getClassLoader().getResourceAsStream("file.txt"); ``` 2. 使用File类的相对路径: ```java File file = new File("src/main/resources/file.txt"); ``` 3. 使用SpringResourceLoader接口: ```java ResourceLoader resourceLoader = new DefaultResourceLoader(); Resource resource = resourceLoader.getResource("classpath:file.txt"); ``` 4. 使用ServletContext.getResourceAsStream()方法: ```java InputStream inputStream = getServletContext().getResourceAsStream("/WEB-INF/classes/file.txt"); ``` 5. 使用SpringResourceUtils类: ```java File file = ResourceUtils.getFile("classpath:file.txt"); ``` 6. 使用SpringResource接口: ```java ClassPathResource resource = new ClassPathResource("file.txt"); InputStream inputStream = resource.getInputStream(); ``` 7. 使用SpringResourcePatternResolver接口: ```java ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); Resource[] resources = resolver.getResources("classpath*:file.txt"); ``` 8. 使用InputStreamResource类: ```java Resource resource = new InputStreamResource(getClass().getClassLoader().getResourceAsStream("file.txt")); ``` 9. 使用PropertiesLoaderUtils类来加载properties文件: ```java Properties properties = PropertiesLoaderUtils.loadProperties(new ClassPathResource("file.properties")); ``` 以上是部分常用的读取resources目录文件的方式,可以根据具体需求选择适合的方式。 ### 回答3: Spring Boot项目中可以使用以下9种方式读取resources目录下的文件: 1. 使用ClassPathResource类来获取资源路径,并使用InputStream或File对象进行读取。 2. 使用ResourceUtils类的`getFile()`方法来获取文件对象。 3. 使用ClassLoader类来获取资源路径,并使用InputStream或File对象进行读取。 4. 使用ServletConfig类的`getServletContext().getRealPath()`方法来获取资源路径,并使用InputStream或File对象进行读取。 5. 使用URL类来获取资源路径,并使用InputStream或File对象进行读取。 6. 使用ResourceLoader类的`getResource()`方法来获取资源路径,并使用InputStream或File对象进行读取。 7. 使用自动装配注解@Value来获取资源路径,并使用InputStream或File对象进行读取。 8. 使用PathMatchingResourcePatternResolver类的`getResources()`方法找到匹配的资源路径,并使用InputStream或File对象进行读取。 9. 使用FileUtils类的`readFileToByteArray()`方法将资源文件转换为字节数组进行读取。 以上9种方式都可以根据具体的需求来选择使用,它们提供了灵活和方便的方式来读取resources目录下的文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值