JavaExcel模板下载

@GetMapping("/download")
@ResponseBody
@RequiresPermissions("o:p:download")
public String fileDownload(HttpServletResponse response, HttpServletRequest request)
{
   String fileName = "xxxx.xlsx";
   try
   {
      String filePath = getClass().getResource("/excel-template/" + fileName).getPath();
      filePath = java.net.URLDecoder.decode(filePath, "utf-8");

      response.setCharacterEncoding("utf-8");
      response.setContentType("multipart/form-data");
      response.setHeader("Content-Disposition", "attachment;fileName=" + setFileDownloadHeader(request, fileName));
      FileUtils.writeBytes(filePath, response.getOutputStream());
      return  "ok";
   }
   catch (Exception e)
   {
      return "error";
   }

}

public String setFileDownloadHeader(HttpServletRequest request, String fileName) throws UnsupportedEncodingException
{
   final String agent = request.getHeader("USER-AGENT");
   String filename = fileName;
   if (agent.contains("MSIE"))
   {
      // IE浏览器
      filename = URLEncoder.encode(filename, "utf-8");
      filename = filename.replace("+", " ");
   }
   else if (agent.contains("Firefox"))
   {
      // 火狐浏览器
      filename = new String(fileName.getBytes(), "ISO8859-1");
   }
   else if (agent.contains("Chrome"))
   {
      // google浏览器
      filename = URLEncoder.encode(filename, "utf-8");
   }
   else
   {
      // 其它浏览器
      filename = URLEncoder.encode(filename, "utf-8");
   }
   return filename;
}

可以把绘制好的模板放在刚刚我们写的下载目录下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值