poi导出excel产生大量临时文件的问题

参考链接: 生成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);
    }

}


两种方式同时存在时,以方式二执行

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值