参考链接: 生成excel时,SXSSFWorkbook POI 临时文件夹“poifiles”问题处理.
poi3-9以下版本导出excel产生大量xml临时文件
方式一:通过升级POI版本,利用dispose释放资源删除临时文件
方式二:手动清除临时文件
临时文件目录
Windows :C:\Windows\Temp\poifiles
Linux: /tmp/poifiles
生成excel时,SXSSFWorkbook POI 临时文件夹“poifiles”问题处理
POI 生成文件时会根据“java.io.tmpdir”配置自动生成 {java.io.tmpdir}/poifiles/,
由于Linux上是生成到 /tmp/poifiles,此目录会被定时清理掉,导致文件无法生成
处理方案:
一、添加启动配置“java.io.tmpdir”
注意事项:
-
此配置并非只有POI使用,其他第三方Jar也使用此配置
-
{java.io.tmpdir}/poifiles/ 目录会在 JVM 停止后自动被清理。
-
不想被清理可配置“poi.keep.tmp.files”数据,只要不为空就不会自动清理(Linux清理/temp还是会被清)
代码逻辑见:org.apache.poi.util.TempFile.DefaultTempFileCreationStrategy#createTempFile
二、通过编码方式设置临时目录
import lombok.extern.slf4j.Slf4j;
import org.apache.poi.util.DefaultTempFileCreationStrategy;
import org.apache.poi.util.TempFile;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import java.io.File;
/**
* POI 生成文件时会根据“java.io.tmpdir”配置自动生成
* 这里指定设置临时目录存放位置
* @author zhou
*/
@Slf4j
@Component
public class ExcelConfig {
private String applicationTmpPath = "D:/fjFile/";
/**
* 设置使用SXSSFWorkbook对象导出excel报表时,TempFile使用的临时目录,代替{java.io.tmpdir}
*/
@PostConstruct
public void setExcelSXSSFWorkbookTmpPath() {
String excelSXSSFWorkbookTmpPath = applicationTmpPath + "/poifiles";
File dir = new File(excelSXSSFWorkbookTmpPath);
if (!dir.exists()) {
dir.mkdirs();
}
TempFile.setTempFileCreationStrategy(new DefaultTempFileCreationStrategy(dir));
log.info("setExcelSXSSFWorkbookTmpPath={}", excelSXSSFWorkbookTmpPath);
}
}
两种方式同时存在时,以方式二执行