springboot下载excel模板

/**
* 描述:下载外部案件导入模板
* @throws Exception
*/
@RequestMapping(value = "/downloadExcel")
@ResponseBody
public void downloadExcel(HttpServletResponse res, HttpServletRequest req,String name) throws Exception {
       String fileName = name+".xlsx";
    ServletOutputStream out;
    res.setContentType("multipart/form-data");
    res.setCharacterEncoding("UTF-8");
    res.setContentType("text/html");
    String filePath = getClass().getResource("/template/" + fileName).getPath();
    String userAgent = req.getHeader("User-Agent");
  if (userAgent.contains("MSIE") || userAgent.contains("Trident")) {
    fileName = java.net.URLEncoder.encode(fileName, "UTF-8");
  } else {
    // 非IE浏览器的处理:
         fileName = new String((fileName).getBytes("UTF-8"), "ISO-8859-1");
  }
  filePath = URLDecoder.decode(filePath, "UTF-8");
  res.setHeader("Content-Disposition", "attachment;fileName=" + fileName);
  FileInputStream inputStream = new FileInputStream(filePath);
  out = res.getOutputStream();
  int b = 0;
  byte[] buffer = new byte[1024];
  while ((b = inputStream.read(buffer)) != -1) {
  // 4.写到输出流(out)中
  out.write(buffer, 0, b);
  }
  inputStream.close();

  if (out != null) {
  out.flush();
  out.close();
  }

}

转载于:https://www.cnblogs.com/DIVEY/p/10598574.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值