博客
关于我
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/

你可能感兴趣的文章
Node.js安装及环境配置之Windows篇
查看>>
Node.js安装和入门 - 2行代码让你能够启动一个Server
查看>>
node.js安装方法
查看>>
Node.js官网无法正常访问时安装NodeJS的方法
查看>>
node.js模块、包
查看>>
node.js模拟qq漂流瓶
查看>>
node.js的express框架用法(一)
查看>>
Node.js的交互式解释器(REPL)
查看>>
Node.js的循环与异步问题
查看>>
Node.js高级编程:用Javascript构建可伸缩应用(1)1.1 介绍和安装-安装Node
查看>>
nodejs + socket.io 同时使用http 和 https
查看>>
NodeJS @kubernetes/client-node连接到kubernetes集群的方法
查看>>
NodeJS API简介
查看>>
nodejs Error: request entity too large解决方案
查看>>
Nodejs express 获取url参数,post参数的三种方式
查看>>
nodejs http小爬虫
查看>>
nodejs libararies
查看>>
vue3+element-plus 项目中 el-switch 刷新后自动触发change?坑就藏在这里!
查看>>
nodejs npm常用命令
查看>>
nodejs npm常用命令
查看>>