前端如何获取响应头Content-Disposition中的filename参数

发布于 2022-09-13 00:29:16 字数 907 浏览 9 评论 0

问题描述

要求在下载文件时的文件名与响应头中的filename参数的取值相同,不使用xxx.txt这种命名.
后端返回的data中只有数据流,要获取文件名只能自己去响应头中获取,但不知道用什么方法获取..

相关代码

粘贴代码文本(请勿用截图)

  this.$axios
    .get(exportF(), { params, responseType: 'blob' }, { headers: { 'Content-Type': 'octet-stream;charset=UTF-8' } })
    .then(({ data }) => {
      console.log(data)
      let blob = new Blob([data], { type: 'application/octet-stream,charset=UTF-8' })
      // console.log(blob)
      let downloadElement = document.createElement('a')
      let href = window.URL.createObjectURL(blob) //创建下载的链接
      downloadElement.href = href
      downloadElement.download = 'xxx.txt' //下载后文件名
      console.log(document)
      document.body.appendChild(downloadElement)
      downloadElement.click() //点击下载
      document.body.removeChild(downloadElement) //下载完成移除元素
      window.URL.revokeObjectURL(href) //释放掉blob对象
    })

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

风情万种。 2022-09-20 00:29:16

首先后端需要设置,否则前端获取不到头信息:

 response.setHeader("Access-Control-Expose-Headers", "Content-Disposition")
 response.setHeader("Content-Disposition", ...)

然后前端可以获取值:

// 省略代码
var temp = res.headers["content-disposition"]
var filenameRegex = /filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/;
var matches = filenameRegex.exec(disposition);
if (matches != null && matches[1]) { 
   filename = matches[1].replace(/['"]/g, '');
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文