博客
关于我
axios 全局拦截
阅读量:523 次
发布时间:2019-03-08

本文共 1628 字,大约阅读时间需要 5 分钟。

import axios from 'axios'import {    getToken }  from './auth'import {    MessageBox, Message } from 'element-ui'import store from '@/store'const service = axios.create({     baseURL: process.env.VUE_APP_BASE_API, // 接口域名地址  timeout: 5000 						// 请求超时时间})//请求拦截器(interceptors.requst)是指可以拦截每次或指定HTTP请求,并可修改配置项service.interceptors.request.use(  config => {       if (getToken()) {         config.headers['X-Token'] = getToken()// 'token'  token是在登录成功的时候才会给你 有的话加到请求头上    }      return config  },  error => {       console.log(error) // for debug    return Promise.reject(error)  })//响应拦截器(interceptors.response)可以在每次HTTP请求后拦截住每次或指定HTTP请求,并可修改返回结果项service.interceptors.response.use(  response => {       const res = response.data    if (res.code !== 20000) {         Message({           message: res.message || 'Error',        type: 'error',        duration: 5 * 1000      })      if (res.code === 50008 || res.code === 50012 || res.code === 50014) {           MessageBox.confirm('You have been logged out, you can cancel to stay on this page, or log in again', 'Confirm logout', {             confirmButtonText: 'Re-Login',          cancelButtonText: 'Cancel',          type: 'warning'        }).then(() => {             store.dispatch('user/resetToken').then(() => {               location.reload()          })        })      }      return Promise.reject(new Error(res.message || 'Error'))    } else {         return res    }  },  error => {       console.log('err' + error)     Message({         message: error.message,      type: 'error',      duration: 5 * 1000    })    return Promise.reject(error)  })export default service

转载地址:http://kvanz.baihongyu.com/

你可能感兴趣的文章
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqlreport分析工具详解
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>