gpt4 book ai didi

springboot中Excel文件下载踩坑大全

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 44 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章springboot中Excel文件下载踩坑大全由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

项目场景:Spring boot文件下载

调用接口下载spring boot工程的resources目录下的excel模板文件,非常常见的一个文件下载功能,但是却容易遇到很多坑,下面总结记录下.

问题一:下载的文件名称出现中文乱码的问题

解决方案:

  1. response.setHeader("Content-Disposition",
  2. "attachment;filename=" + new String("下载模板".getBytes("UTF-8"), "ISO8859-1"));

说明: 这是网上最常见的解决方案,经过这样的修改后,在浏览器上调用get请求下载的文件确实没有出现文件名中文乱码了。 但是在swagger里面测试接口,下载的问题还是会出现中文乱码.

问题二:在swagger中测试下载接口,点击下载的文件,发现文件名是乱码的问题

这里我项目中使用的是springdoc-openapi-ui 1.5.9,基于的是openapi3.0的协议。 整体使用方式和界面和swagger类似.

swagger中下载的文件,点击开发后,文件名乱码问题:

springboot中Excel文件下载踩坑大全

解决方案:

  1. response.setHeader("Content-Disposition", "attachment;fileName=" +
  2. URLEncoder.encode("线索导入模板.xlsx","utf8"));

说明: 通过URLEncoder.encode函数对文件名称处理后,无论是在浏览器调用GET请求下载文件,还是Swagger中调用下载接口,都不会出现文件名乱码问题.

问题三:下载的excel文件打开时总是提示部分内容有问题,尝试恢复.

springboot中Excel文件下载踩坑大全

springboot中Excel文件下载踩坑大全

解决办法: 给response的Header设置大小:

  1. /加上设置大小 下载下来的excel文件才不会在打开前提示修复
  2. response.addHeader("Content-Length",String.valueOf(file.length()));

问题四:开发环境下载成功,打成jar包发布到服务器上部署就出现下载失败问题

原因: Resource下的文件是存在于jar这个文件里面,在磁盘上是没有真实路径存在的,它其实是位于jar内部的一个路径。所以通过ResourceUtils.getFile或者this.getClass().getResource("")方法无法正确获取文件.

解决: 通过ClassPathResource读取文件流 。

  1. ClassPathResource classPathResource = new ClassPathResource("template/template.xlsx");

完整代码

1、控制层代码 。

  1. @Operation(summary = "下载模版",description = "下载模版")
  2. @GetMapping("/download")
  3. public void download(HttpServletResponse response){
  4. templateService.download(response);
  5. }

2、下载方法实现 。

  1. /**
  2. * 下载线索模板
  3. * @param response
  4. */
  5. public void download(HttpServletResponse response) {
  6. InputStream inputStream = null;
  7. BufferedInputStream bis = null;
  8. OutputStream outputStream = null;
  9. try {
  10. ClassPathResource classPathResource = new ClassPathResource("template/template.xlsx");
  11. inputStream = classPathResource.getInputStream();
  12.  
  13. response.setContentType("application/octet-stream");
  14. response.setHeader("content-type", "application/octet-stream");
  15. //待下载文件名
  16. String fileName = URLEncoder.encode("模板.xlsx","utf8");
  17. response.setHeader("Content-Disposition", "attachment;fileName=" + fileName);
  18. //加上设置大小 下载下来的excel文件才不会在打开前提示修复
  19. response.addHeader("Content-Length",String.valueOf(classPathResource.getFile().length()));
  20.  
  21. byte[] buff = new byte[1024];
  22. outputStream = response.getOutputStream();
  23. bis = new BufferedInputStream(inputStream);
  24. int read = bis.read(buff);
  25. while (read != -1) {
  26. outputStream.write(buff, 0, buff.length);
  27. outputStream.flush();
  28. read = bis.read(buff);
  29. }
  30. } catch ( IOException e ) {
  31. log.error("文件下载失败,e");
  32. } finally {
  33. IOUtils.closeQuietly(outputStream);
  34. IOUtils.closeQuietly(inputStream);
  35. IOUtils.closeQuietly(bis);
  36. }
  37. }

参考:https://blog.csdn.net/Hi_Boy_/article/details/107198371 。

到此这篇关于springboot中Excel文件下载踩坑大全的文章就介绍到这了,更多相关springboot Excel文件下载内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/w1014074794/article/details/118549310 。

最后此篇关于springboot中Excel文件下载踩坑大全的文章就讲到这里了,如果你想了解更多关于springboot中Excel文件下载踩坑大全的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

44 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com