zoukankan      html  css  js  c++  java
  • 压缩多个excel成一个压缩包,浏览器下载

    https://blog.csdn.net/Fannie08/article/details/84252684

     https://blog.csdn.net/weixin_33895016/article/details/86022623

    首先明白一点;

      请求--响应

    输入流--输出流。

      一个输入流;一个输出流

    不可能一个输出流同时多次传输下载多个文件,只能一次传输下载,如果要同时下载多个文件,就采用压缩包的方式一次传输下载。

    java.util.zip

    核心类:

    压缩包的输出流:

    ZipOutputStream:

      public ZipOutputStream(OutputStream out);

      public void putNextEntry(ZipEntry e);

    压缩包中一个元素定义:

    public ZipEntry(String name);

    多个文件就封装多个ZipEntry;

    将XSSFWorkbook转成输入流的方法:

    public static InputStream workbookToInpustream(XSSFWorkbook workbook) {
    try {
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    workbook.write(bos);
    byte[] barray = bos.toByteArray();
    return new ByteArrayInputStream(barray);
    } catch (IOException e) {
    e.printStackTrace();
    }
    return null;
    }

    controller层:
    @ResponseBody
    @RequestMapping("/exportZipFile")
    public void exportZipFile(HttpServletResponse response) throws Exception {
    String currTime = "2020-03-25";
    response.setContentType("application/octet-stream");
        //如果输出的是中文名的文件,在此处就要用URLEncoder.encode方法进行处理
           // 处理方法1 response.setHeader("Content-Disposition", "attachment;filename=" +URLEncoder.encode(file.getName(), "UTF-8"));
        //处理方法2
    String zipfileName= new String(("报表数据-"+currTime).getBytes(), "iso-8859-1");
    response.setHeader("Content-Disposition", "attachment; filename="+zipfileName+".zip");
    ZipOutputStream zos = null;
    XSSFWorkbook book1;
    XSSFWorkbook book2;
    book1 = new XSSFWorkbook(new File("D:\jo1.xlsx"));
    book2 = new XSSFWorkbook(new File("D:\jo2.xlsx"));
    List<XSSFWorkbook> workbooks = new ArrayList<>();
    workbooks.add(book1);
    workbooks.add(book2);
    try {
    zos = new ZipOutputStream(response.getOutputStream());
    //循环把文件流添加到压缩包中
    for (int i = 0; i < workbooks.size(); i++) {
    XSSFWorkbook workbook = workbooks.get(i);
    //获取文件流
    InputStream input = workbookToInpustream(workbook);
    //压缩文件名称 设置ZipEntry对象
    String name="bookname"+i;
    zos.putNextEntry(new ZipEntry(name + ".xlsx"));
    // 设置注释
    zos.setComment("日检查报表");
    int temp;
    // 读取内容
    while ((temp = input.read()) != -1) {
    // 压缩输出
    zos.write(temp);
    }
    input.close();
    }
    } catch (Exception e) {
    e.printStackTrace();

    } finally {
    try {
    if (null != zos) {
    zos.flush();
    zos.close();
    }
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    }
     
  • 相关阅读:
    kubernetes集群系列资料08--deployment介绍
    kubernetes集群系列资料07--RS介绍
    kubernetes集群系列资料06--pod介绍
    kubernetes集群系列资料05--K8S集群命令介绍
    kubernetes集群系列资料04--harbor部署
    uwsgi + nginx 部署python项目(一)
    argparse命令行传参
    Flask的 sqlalchemy 操作要点
    mysql: show full processlist 详解
    MySQL数据库的连接池问题
  • 原文地址:https://www.cnblogs.com/mjbenkyo/p/12569402.html
Copyright © 2011-2022 走看看