【记录】实现从Linux下载下载文件(文件导出功能)并记录过程产生的BUG问题。

前言

导出功能的实现,主要记录总结导出过程中出现的一些问题。

代码实现导出功能

java 复制代码
    public R templateDown(HttpServletResponse response) {
        String fileName = "template.xlsx";
        // 清空response
        response.reset();
        response.setCharacterEncoding("UTF-8");
        response.setContentType("application/x-msdownload");
        try {
            //解决乱码
            String exportName = "导入模板.xlsx";
            String fileNameCode = URLEncoder.encode(exportName,"UTF-8");
            response.setHeader("Content-Disposition", "attachment;fileName=" + fileNameCode);
            //获取文件路径
            String fileUrl = emergencyPath;
            //获取项目在服务器上的真实路径
            fileUrl = fileUrl + File.separator + fileName;

            File file = new File(fileUrl);
            if (!file.exists()) {
//                response.sendError(500, "File not found!");
                return R.fail("模板文件不存在");
            }
            long fileLength = file.length();
            response.setHeader("Content-Length", String.valueOf(fileLength));
            BufferedInputStream bis = new BufferedInputStream(new FileInputStream(file));
            BufferedOutputStream bos = new BufferedOutputStream(response.getOutputStream());
            byte[] buff = new byte[2048];
            int bytesRead;
            while (-1 != (bytesRead = bis.read(buff, 0, buff.length))) {
                bos.write(buff, 0, bytesRead);
            }
            bis.close();
            bos.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return R.success("导出成功");
    }

问题总结

  1. 导出文件名、文件内容乱码问题,以下几种情况可尝试解决该问题
  • 设置参数前response清空,有些情况可通过reset()解决。
java 复制代码
// 清空response
response.reset();
  • 对导出的文件名编码处理:
java 复制代码
String fileNameCode = URLEncoder.encode(exportName,"UTF-8");
response.setHeader("Content-Disposition", "attachment;fileName=" + fileNameCode);
  • 也是一种编码处理,和第二种方式差不多,都是对文件头设置:
java 复制代码
fileName = URLEncoder.encode(fileName,"utf-8");
response.addHeader("Content-Disposition",
                    "attachment;filename=" + new String(fileName.getBytes("utf-8"),"ISO8859-1"));
  1. 文件路径、文件名都是对的,但是通过new File(path)一直返回找不到文件。
    原因:服务器的文件名是不是中文名,如果是中文名可能会出现即使路径都写对了,仍出现文件找不到的问题。强烈建议服务器上文件名用英文!!!
相关推荐
寻星探路4 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
曹牧6 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
wdfk_prog7 小时前
[Linux]学习笔记系列 -- [drivers][input]input
linux·笔记·学习
爬山算法7 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
盟接之桥7 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
kfyty7257 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎7 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄7 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿7 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能