前端如何获取响应头Content-Disposition中的filename参数
问题描述
要求在下载文件时的文件名与响应头中的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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
更多
发布评论
评论(1)
首先后端需要设置,否则前端获取不到头信息:
然后前端可以获取值: