• SpringBoot 接口输出文件流 & Vue 下载文件流,获取 Header 中的文件名


    SpringBoot 接口输出文件流 & Vue 下载文件流,获取 Header 中的文件名

    @GetMapping("/download") 
    public ResponseEntity<FileSystemResource> download(HttpServletRequest request) {
        File file = new File("D:\\VipSoft.zip");
        HttpHeaders headers = new HttpHeaders();
        headers.add("Cache-Control", "no-cache, no-store, must-revalidate");
        headers.add("Content-Disposition", "attachment; filename=" + URLEncoder.encode(file.getName(), "UTF-8")); 
        headers.add("filename",  URLEncoder.encode(file.getName(), "UTF-8"));
        headers.add("Access-Control-Expose-Headers", "filename");  //这个要加,否则Vue 在 res.headers['filename'] 时取不到值
        headers.add("Pragma", "no-cache");
        headers.add("Expires", "0");
        headers.add("Last-Modified", new Date().toString());
        headers.add("ETag", String.valueOf(System.currentTimeMillis()));
        return ResponseEntity.ok().headers(headers).contentLength(file.length()).contentType(MediaType.parseMediaType("application/octet-stream")).body(new FileSystemResource(file));
    }

    Vue 中获取不到 后面传的 header 是因为少加了 "Access-Control-Expose-Headers"

    instance.interceptors.response.use(
      response => {
        if (response.status >= 200 && response.status < 300) {
            var blob = new Blob([response.data], {type: 'application/octet-stream'});
            var downloadElement = document.createElement('a');
            var href = window.URL.createObjectURL(blob); //创建下载的链接
            downloadElement.href = href;
            downloadElement.download = filename; //下载后文件名
            document.body.appendChild(downloadElement);
            downloadElement.click(); //点击下载
            document.body.removeChild(downloadElement); //下载完成移除元素
            window.URL.revokeObjectURL(href); //释放掉blob对象
          return response.data
        } else {
          Message({
            message: '请求错误' + response.status,
            type: 'error',
            duration: 5 * 1000
          })
          return Promise.reject(response)
        }
      },
      error => {
        console.log('err' + error)// for debug
        Message({
          message: error.message,
          type: 'error',
          duration: 5 * 1000
        })
        return Promise.reject(error)
      })
  • 相关阅读:
    数值拓展与函数拓展
    正则小记
    Struts2(三)配置详解
    Struts2(二)工作原理
    Struts2(一)基本配置
    Eclipse新建动态web工程项目出现红叉解决方案
    Spring系列之AOP
    Java动态代理的实现机制
    Spring系列之装配Bean
    Spring系列之基本配置
  • 原文地址:https://www.cnblogs.com/vipsoft/p/16662762.html
Copyright © 2020-2023  润新知