123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- 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
|