Axios发送post请求下载文件
程序员文章站
2024-03-20 17:32:46
...
发送post请求下载文件
先说一下背景:这是一个以vue作为框架并用Axios来发送http请求的项目。我想要实现用axios来发送post请求,然后服务器会返回的response是一个文件流,我希望能将这个文件流写入excel,从而实现该excel文件的下载。
在网上查阅了相关资料后,我在Axios官方文档给出的一个不大完整的示例中看到一种基于node原生模块fs的处理方案,我考虑到是否可以采用这种方式来处理我接受到的文件流,可是经过尝试,发现行不通。
以下是我亲试可以实现的一种方案:
exportData () {
const form = this.getSearchForm() // 要发送到后台的数据
axios({ // 用axios发送post请求
method: 'post',
url: '/user/12345', // 请求地址
data: form, // 参数
responseType: 'blob' // 表明返回服务器返回的数据类型
})
.then((res) => { // 处理返回的文件流
const content = res
const blob = new Blob([content])
const fileName = '测试表格123.xls'
if ('download' in document.createElement('a')) { // 非IE下载
const elink = document.createElement('a')
elink.download = fileName
elink.style.display = 'none'
elink.href = URL.createObjectURL(blob)
document.body.appendChild(elink)
elink.click()
URL.revokeObjectURL(elink.href) // 释放URL 对象
document.body.removeChild(elink)
} else { // IE10+下载
navigator.msSaveBlob(blob, fileName)
}
})
}
这里用了Blob对象,上面的写法就是用从服务器接收到的文件流(content-type:application/octet-stream)创建了一个blob对象,并使用该blob 创建一个指向类型数组的URL,将该url作为a标签的链接目标,然后去触发a标签的点击事件从而实现表格下载。
上一篇: 阿里巴巴EasyExcel导入导出(model版本)
下一篇: 34、数字在排序数组中出现的次数
推荐阅读
-
Vue axios 后端返回excel文件流改如何下载
-
axios 请求下载文件excel,后端返回二进制的文件
-
Axios发送post请求下载文件
-
vue中使用axios下载java后台返回文件流导出excel文档
-
axios实现文件下载,附前后端代码
-
Vue项目利用axios请求接口下载excel(附前后端代码)
-
PHP中的使用curl发送请求(GET请求和POST请求)
-
用httpclient4.x 发送http get post请求 中文编码问题 博客分类: 技术总结HttP httpclient4.xgetpost中文编码
-
java 发送带Basic Auth认证的http post请求实例代码
-
java发送http的get、post请求实现代码