vue ajax 拦截原理与实现方法示例


Posted in Javascript onNovember 29, 2019

本文实例讲述了vue ajax 拦截原理与实现方法。分享给大家供大家参考,具体如下:

概要说明

在开发的过程中,我们需要通过AJAX请求,访问后台获取数据,这个获取数据的时候,当然需要后台需要时登录状态才能访问数据,当没有登录的情况,这个时候我们需要跳转到登录界面进行登录。

如果每次请求都要做如下处理,我们程序逻辑将无比混乱,ajax 可以为我们解决这个问题。

具体实现思路是:

1.发送ajax 请求访问后端数据。

2.后端如果发现没有登录,那么将会丢出一个exceptionaction 的http 响应头。

3.这个判断将在ajax 拦截中处理,只要有这个响应头,我们会检查是否有登录token,如果没有就会去到登录界面,如果有则尝试使用token自动登录。

这个过程将在拦截中完成。

这个好处是 客户只需要关注业务代码的编写,登录处理放到拦截中处理,而且所有的请求将都会被拦截。

实现代码

const axiosInstance = axios.create({
  timeout: 20000,
  headers: {
    'Content-Type': 'application/x-www-form-urlencoded',
    'X-Requested-With': 'XMLHttpRequest'
  }
});

axios 是我们访问后台的JS框架。

定义拦截处理。

function interceptAjax(res){
  var tmp = res.headers["exceptionaction"];
  if(!tmp) return res;
  //系统已经登录。
  var token = RxUtil.getCache("token");
  if(!token) {
    router.push({
      name: "login"
    });
    return;
  }

使用拦截器。

axiosInstance.interceptors.response.use(res=>interceptAjax(res));

这样每次访问都会经过拦截器,这也给我们一些思路,一些需要统一验证的的访问,可以通过拦截器进行处理。

希望本文所述对大家vue.js程序设计有所帮助。

Javascript 相关文章推荐
jQuery 动画弹出窗体支持多种展现方式
Apr 29 Javascript
基于jquery的一个浮动框(扩展性比较好 )
Aug 27 Javascript
javascript模版引擎-tmpl的bug修复与性能优化分析
Oct 23 Javascript
JS中使用sort结合localeCompare实现中文排序实例
Jul 23 Javascript
JavaScript判断文件上传类型的方法
Sep 02 Javascript
Firefox下无法正常显示年份的解决方法
Sep 04 Javascript
深入分析Javascript跨域问题
Apr 17 Javascript
实例详解JSON取值(key是中文或者数字)方式
Aug 24 Javascript
Node.js如何使用Diffie-Hellman密钥交换算法详解
Sep 05 Javascript
Angular数据绑定机制原理
Apr 17 Javascript
vue实现分页组件
Jun 16 Javascript
vue 清空input标签 中file的值操作
Jul 21 Javascript
VUE 实现动态给对象增加属性,并触发视图更新操作示例
Nov 29 #Javascript
js中关于Blob对象的介绍与使用
Nov 29 #Javascript
js blob类型url的视频下载问题的解决
Nov 29 #Javascript
JavaScript之Blob对象类型的具体使用方法
Nov 29 #Javascript
VuePress 中如何增加用户登录功能
Nov 29 #Javascript
Vue.directive 实现元素scroll逻辑复用
Nov 29 #Javascript
Vue.js实现大屏数字滚动翻转效果
Nov 29 #Javascript
You might like
Amazon Prime Video平台《无限住人 -IMMORTAL-》2020年开始TV放送!
2020/03/06 日漫
php中关于codeigniter的xmlrpc的类在进行数据交换时的类型问题
2011/07/03 PHP
通过PHP设置BugFree获取邮箱通知
2019/04/25 PHP
使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇
2010/05/07 Javascript
jQuery Tab插件 用于在Tab中显示iframe,附源码和详细说明
2011/06/27 Javascript
js replace 与replaceall实例用法详解
2013/08/03 Javascript
使用Meteor配合Node.js编写实时聊天应用的范例
2015/06/23 Javascript
Bootstrap框架动态生成Web页面文章内目录的方法
2016/05/12 Javascript
JS hashMap实例详解
2016/05/26 Javascript
基于JavaScript实现轮播图原理及示例
2020/04/10 Javascript
vue2.0 兄弟组件(平级)通讯的实现代码
2018/01/15 Javascript
vue集成chart.js的实现方法
2019/08/20 Javascript
微信小程序后端实现授权登录
2020/02/24 Javascript
Vue中keep-alive的两种应用方式
2020/07/15 Javascript
python回溯法实现数组全排列输出实例分析
2015/03/17 Python
如何准确判断请求是搜索引擎爬虫(蜘蛛)发出的请求
2015/10/13 Python
Python 类与元类的深度挖掘 I【经验】
2016/05/06 Python
Python pass详细介绍及实例代码
2016/11/24 Python
基于pandas数据样本行列选取的方法
2018/04/20 Python
Django中日期处理注意事项与自定义时间格式转换详解
2018/08/06 Python
pyqt5实现俄罗斯方块游戏
2019/01/11 Python
python线程信号量semaphore使用解析
2019/11/30 Python
python异常处理、自定义异常、断言原理与用法分析
2020/03/23 Python
Python中无限循环需要什么条件
2020/05/27 Python
Python基于gevent实现文件字符串查找器
2020/08/11 Python
Python字符串查找基本操作代码案例
2020/10/27 Python
python基于win32api实现键盘输入
2020/12/09 Python
中间件分为哪几类
2012/03/14 面试题
网站客服岗位职责
2014/04/05 职场文书
煤矿安全生产责任书
2014/04/15 职场文书
批评与自我批评发言稿
2014/10/15 职场文书
评先进个人材料
2014/12/29 职场文书
2016年母亲节广告语
2016/01/28 职场文书
优秀家长事迹材料(2016推荐版)
2016/02/29 职场文书
大学迎新生的欢迎词
2019/06/25 职场文书
Python类方法总结讲解
2021/07/26 Python