SpringBoot ResponseEntity + axios 下载文件

后端:

// 设置响应头
HttpHeaders headers = new HttpHeaders();
// 文件名URLEncoder.encode(fileName,"UTF-8") 防止中文乱码
headers.setContentDispositionFormData("attachment", URLEncoder.encode(fileName,"UTF-8"));
headers.setContentLength(bytes.length);
headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
headers.set("fileName", URLEncoder.encode(fileName,"UTF-8"));
// setAccessControlExposeHeaders 设置这个前端才能取到
headers.setAccessControlExposeHeaders(Arrays.asList(HttpHeaders.CONTENT_DISPOSITION,
        HttpHeaders.CONTENT_LENGTH, HttpHeaders.CONTENT_TYPE));
// bytes 文件字节数组
return ResponseEntity.status(HttpStatus.SC_OK).headers(headers).body(bytes);

前端:

    /**
     * url: 下载地址
     * defaultFileName: 默认文件名(若前端已知文件名)
     * data: 请求参数
     */
    downloadFile(url, defaultFileName, data) {
      axios({
        url,
        method: "post",
        responseType: "blob",
        data,
      }).then((response) => {
        let fileName;
        const { data: body } = response;
        // 这里要注意 content-disposition全小写
        const contentDisposition = response.headers["content-disposition"];
        if (contentDisposition) {
          // filename 同样全小写
          var filenameRegex = /filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/;
          var matches = filenameRegex.exec(contentDisposition);
          if (matches != null && matches[1]) {
            fileName = matches[1].replace(/['"]/g, "");
          }
        }

        if (body) {
          let file = new Blob([body], {
            type: "application/octet-stream",
          });
          var downloadElement = document.createElement("a");
          var href = window.URL.createObjectURL(file);
          downloadElement.href = href;
          downloadElement.download = decodeURIComponent(fileName || defaultFileName);
          document.body.appendChild(downloadElement);
          downloadElement.click();
          document.body.removeChild(downloadElement);
          window.URL.revokeObjectURL(href);
        } else {
          // 下载失败的处理
        }
      });
    },
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值