Excel模板下载

Controller层

@GetMapping("download")
@ApiOperation("下载模板")
public void downLoadFile(@RequestParam String type, HttpServletResponse response) {
    String fileName = "house".equals(type) ? "附件一:xxx.xlsx" : "developer".equals(type) ? "附件二:xxx.xlsx" : "intention".equals(type) ? "附件三:xxx.xlsx":"";
    try {

        WebUtil.downloadFile(response, fileName, "listData/");  //此处listData文件下存放excel模板以供下载
    } catch (IOException e) {
        log.error("[清单管理]", e);
    }
}

WebUtil公用方法

/**
 * @return void
 * @throws
 * @description linux中获取文件路径有问题,建议用此种方法进行下载
 * @Param [response, fileName]
 */
public static void downloadFile(HttpServletResponse response, String fileName, String filePath) throws IOException {
    if (StringUtils.isNotBlank(fileName)) {
        InputStream stream = WebUtil.class.getClassLoader().getResourceAsStream(filePath + fileName);
        @Cleanup BufferedInputStream bis = new BufferedInputStream(stream);
        writeResponse(response, fileName, bis);
    }
}

 

/**
 * @return void
 * @throws
 * @description 向response中写入文件
 * @Param [response, fileName, bis]
 */
private static void writeResponse(HttpServletResponse response, String fileName, BufferedInputStream bis) throws IOException {
    response.setCharacterEncoding("utf-8");
    // 设置强制下载不打开application/force-download
    response.setContentType("application/octet-stream");
    //设置文件名称
    response.addHeader("Content-Disposition", "attachment;fileName=" + URLEncoder.encode(fileName, "utf-8"));
    OutputStream os = response.getOutputStream();
    byte[] buffer = new byte[1024];
    int i = bis.read(buffer);
    while (i != -1) {
        os.write(buffer, 0, i);
        i = bis.read(buffer);
    }
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值