问题描述:
使用vue.js 下载文件的时候,设置的类型是'Blob',axios请求接口下载,请求成功时返回的是一个流形式的文件,但是请求失败的时候返回的是json ,需要用默认的responseType: 'json'来处理错误信息,那么问题来了,我该怎么根据服务器响应后才设置这个responseType?
问题重现:
请求设置了responseType: 'Blob',
请求成功时,下载文件
请求失败时,后端返回json对象,如:{"msg":"系统异常","code":1,"success":false},也被转成了arraybuffer
解决办法:
api.downloadFile(params).then(res => {
if (res.status === 200 && res.data) {
var disposition = res.headers['content-disposition']
var fileName = decodeURI(disposition.substring(disposition.indexOf('filename=') + 9, disposition.length))
let blob = new Blob([res.data], { type: 'application/pdf' }) // 假设文件为pdf
let link = document.createElement('a')
link.href = window.URL.createObjectURL(blob)
link.download = fileName
link.click()
link.remove()
} else {
// 其它情况
}
}).catch(err => {
var enc = new TextDecoder('utf-8')
var res = JSON.parse(enc.decode(new Uint8Array(err.data))) //转化成json对象
console.log(res)
})