直接修改响应配置即可 读取 res.headers['content-disposition']
![在这里插入图片描述](https://img-blog.csdnimg.cn/348708cc8a344235b64f8df0663e0564.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/31f25d7e2c13429d96986f478f743f7a.png)
下面直接上我的axios配置文件
import axios from 'axios'
import { Notification, MessageBox, Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'
import errorCode from '@/utils/errorCode'
import { tansParams } from "@/utils/ruoyi";
axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8'
const service = axios.create({
baseURL: process.env.VUE_APP_BASE_API,
timeout: 100000
})
service.interceptors.request.use(config => {
const isToken = (config.headers || {}).isToken == false
if (getToken() && !isToken) {
config.headers['Authorization'] = 'Bearer ' + getToken()
}
return config
}, error => {
console.log(error)
Promise.reject(error)
})
service.interceptors.response.use(res => {
const code = res.data.code || 200;
if(res.headers['content-disposition']){
res.data.contentDisposition = res.headers['content-disposition']
}
const msg = errorCode[code] || res.data.msg || errorCode['default']
if (code == 401) {
MessageBox.confirm(
'登录状态已过期,您可以继续留在该页面,或者重新登录',
'系统提示',
{
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}
).then(() => {
store.dispatch('LogOut').then(() => {
location.reload()
})
})
} else if (code == 500) {
Message({
message: msg,
type: 'error'
})
return Promise.reject(new Error(msg))
} else if (code !== 200) {
Notification.error({
title: msg
})
return Promise.reject('error')
} else {
return res.data
}
},
error => {
console.log('err' + error)
let { message } = error;
if (message == "Network Error") {
message = "后端接口连接异常";
}
else if (message.includes("timeout")) {
message = "系统接口请求超时";
}
else if (message.includes("Request failed with status code")) {
message = "系统接口" + message.substr(message.length - 3) + "异常";
}
Message({
message: message,
type: 'error',
duration: 5 * 1000
})
return Promise.reject(error)
}
)
export function download(url, params, filename) {
return service.post(url, params, {
transformRequest: [(params) => {
return tansParams(params)
}],
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
},
responseType: 'blob'
}).then((data) => {
const content = data
const blob = new Blob([content])
if ('download' in document.createElement('a')) {
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)
document.body.removeChild(elink)
} else {
navigator.msSaveBlob(blob, filename)
}
}).catch((r) => {
console.error(r)
})
}
export default service