热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

vue中用axios拦截器拦截请求和响应

importaxiosfromaxios引入模块varapiaxios.create({baseURL:ENV,timeout:5000,headers:{Content-Type

import axios from 'axios'引入模块

var api = axios.create({baseURL: ENV,timeout: 5000,headers: {'Content-Type': 'application/json'}
})
// request请求配置
api.interceptors.request.use(config => {config.headers['system'] = apiconfig.SYSTEMif (sessionStorage) {const token = sessionStorage.getItem(apiconfig.TOKEN_KEY)if (token) {config.headers['Authorization'] = 'bearer ' + token // 让每个请求携带token--['X-Token']为自定义key 请根据实际情况自行修改}return config} else {Notification({title: '错误',message: '您的浏览器版本太低,请升级浏览器',type: 'error'})}}, error => {console.error(error)Notification({title: '错误',message: '请求失败:' + error.message,type: 'error'})Promise.reject(error)
})
// respone拦截器
api.interceptors.response.use(response => {return response}, error => {let errorMsg = ''if (error.toString().indexOf('timeout') !== -1) {errorMsg = '连接服务器超时'} else {const errorStatus = error.response.statusconst resErrorMsg = errorStatus + ':' + error.response.data.messageswitch (errorStatus) {case 401:router.push('/login')window.sessionStorage.removeItem(apiconfig.TOKEN_KEY)window.sessionStorage.removeItem(APP_TABVIEWLIST_KEY)store.commit('SET_TAB_VIEW_LIST', [])// console.log('match', router.currentRoute)Notification({title: '请重新登录',message: '登录已过期,请重新登录',showIcon: true,center: true,type: 'error'})returncase 403:errorMsg = '没有权限'breakcase 404:errorMsg = '请求路径找不到'breakcase 422:errorMsg = resErrorMsg + ':' + JSON.stringify(error.response.data.data)breakdefault:// console.log('.api..baseURL.......', resErrorMsg)errorMsg = resErrorMsg}}Notification({title: '错误',message: errorMsg,dangerouslyUseHTMLString: true,type: 'error',customClass: 'tolos-msg'})return Promise.reject(error)})
export default api




推荐阅读
  • 使用ffmpeg进行视频格式转换的简单例子2006-12-1623:12主要参考FFMPEG里面的apiexample.c以及output_example.c编写intmain(in ... [详细]
  • 历史指对人类社会过来的事件和流动,以及对这些事件行为有零碎的记录、钻研和诠释。历史是文化的传承,积攒和扩大,是人类文明的轨迹。APISpace的历史上的 ... [详细]
  • iOS网络开发(7)大牛们的杰作AFNetworking
    本篇文章介绍传说中的 AFN框架的使用AFNetworking是iOS开发中最广泛使用的开源项目之一,是最活跃最有影响力的开源项目之一。    ... [详细]
  • Linux数据链路层的包解析仅以此文作为学习笔记,初学者,如有错误欢迎批评指正,但求轻喷。一般而言,Linux系统截获数据包后,会通过协议栈,按照TCPIP层次进行解析,那我们如何 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 一、在androidStudio中实现tabs比较简单,新建项目就可以选择tabs模板进行创建,默认实现tabs功能:直接运行项目就可以看到效果:可以说非常简单,但是我们在实际开发 ... [详细]
  • QT串口通信文章目录QT串口通信前言一、Pycharm代码二、STM32代码前言前几天学了QT,只设计界面并没有用处,于是我便学习了QT的串口通信。Q ... [详细]
  • 一、域名解析记录说明记录类型A:用来指定域名的IPv4地址(如:8.8.8.8),如果需要将域名指向一个IP ... [详细]
  • 本文整理了Java中org.assertj.core.api.AbstractCharSequenceAssert.hasSize()方法的一些代码示例,展示了 ... [详细]
  • 这篇文章主要讲解了“GradeBook类怎么定义”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Grad ... [详细]
  • DDD在微服务架构中落地应用
    1DDDDomainDrivenDesign(领域驱动设计,DDD),不是一种架构,而是一种架构方法论,是一种拆解业务、划分业务、确定业 ... [详细]
  • 1、概念共享内存:共享内存是进程间通信中最简单的方式之一。共享内存允许两个或更多进程访问同一块内存,就如同malloc()函数向不同进程返回了指向同一个 ... [详细]
  • NGUIusingSystem;usingUnityEng ... [详细]
  • php实现中文文件下载
    php教程|PHP源码php实现中文文件下载php教程-PHP源码php代码爱之谷2015源码,ubuntu16桌面,tomcat9解压缩半,python爬虫带页面,php批量删除 ... [详细]
  • SQLPLUS 命令
    定制:sql提示符信息1、显示SQLPLUS帮助,命令如下:HELPINDEX@COPYPAUSESHUTDOWN@@DEFINEPRINTSPOOLDELPR ... [详细]
author-avatar
飞天美术_888_265
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有