import axios from 'axios' import { serialize } from '@/util' import NProgress from 'nprogress' // progress bar import errorCode from '@/const/errorCode' import { ElMessage, ElMessageBox } from 'element-plus' import 'nprogress/nprogress.css' import qs from 'qs' import store from '@/store' import router from '@/router/index.js' import { baseUrl } from '@/config/env' // progress bar style axios.defaults.timeout = 30000 // 返回其他状态吗 axios.defaults.validateStatus = function(status) { return status >= 200 && status <= 500 // 默认的 } // 跨域请求,允许保存cookie axios.defaults.withCredentials = true // NProgress Configuration NProgress.configure({ showSpinner: false }) // HTTPrequest拦截 axios.defaults.baseURL = baseUrl axios.interceptors.request.use(config => { NProgress.start() // start progress bar const isToken = (config.headers || {}).isToken === false const token = store.getters.access_token if (token && !isToken) { config.headers['Authorization'] = 'Bearer ' + token// token } // headers中配置serialize为true开启序列化 if (config.method === 'post' && config.headers.serialize) { config.data = serialize(config.data) delete config.data.serialize } if (config.method === 'get') { config.paramsSerializer = function(params) { return qs.stringify(params, { arrayFormat: 'repeat' }) } } return config }, error => { return Promise.reject(error) }) // HTTPresponse拦截 axios.interceptors.response.use(res => { NProgress.done() const status = Number(res.status) || 200 const message = res.data.msg || errorCode[status] || errorCode['default'] if (status == 401){ window.open("http://localhost:3000/") } // 后台定义 424 针对令牌过去的特殊响应码 if (status === 424) { ElMessageBox.confirm('令牌状态已过期,请点击重新登录', '系统提示', { confirmButtonText: '重新登录', cancelButtonText: '取消', type: 'warning' } ).then(() => { store.dispatch('LogOut').then(() => { // 刷新登录页面,避免多次弹框 window.location.reload() }) }).catch(() => { }) return } if (status !== 200 || res.data.code === 1) { ElMessage({ message: message, type: 'error' }) return Promise.reject(new Error(message)) } return res }, error => { // 处理 503 网络异常 console.log(error) if (error.response.status === 503) { ElMessage({ message: error.response.data.msg, type: 'error' }) } NProgress.done() return Promise.reject(new Error(error)) }) export default axios