axios 处理 302 状态码的解决方法


Posted in Javascript onApril 10, 2018

比如说浏览器打开了一个单页面(SPA)应用,过了一段时间token(或者session)过期了,这个时候页面上发起 Ajax请求之后,后端返回302状态码跳转到login页面。 我这是使用的是 Vue + axios ,发现 axios 无法拦截到 302请求,下面是处理的过程。

思考

google axios 302 handle 看到 axios github 上的两个讨论

•  https://github.com/axios/axios/issues/932

•  https://github.com/axios/axios/issues/980

得到的结论就是:浏览器发送的ajax请求,服务端返回了302状态码,浏览器会自行跳转,我们无法通过 js 库(jquery, axios) 直接得到并自定义处理流程,只能等到浏览器重定向之后的url获取相应信息。

axios 发送ajax -->
server 返回302和location -->
浏览器请求新的url -->
服务端返回200 -->

axios 获取结果

那么怎么解决呢?需要服务端配合解决

Brower (ajax and not auth) -->
server判断是ajax请求,未登陆,返回 401状态码 -->
浏览器 axios 拦截401,并且通过js 跳转到 /login

解决

浏览器端, axios 增加拦截器

axios.interceptors.response.use((response) => {
  return response;
}, function (error) {
  if (401 === error.response.status) {
    window.location = '/login';
  } else {
    return Promise.reject(error);
  }
});
axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest';

后端代码,使用flask框架,看个流程就行,验证请求是否是 ajax 和 未登陆,然后返回401状态码

from flask import Blueprint, request, jsonify, make_response, abort
from flask_login.utils import current_user, current_app
apibp = Blueprint('api', 'api_bp')
# 主要逻辑
def bp_login_required():
  if not current_user.is_authenticated:
    if request.is_xhr:
      abort(401)
    else:
      return current_app.login_manager.unauthorized()
apibp.before_request(bp_login_required)
@apibp.route("/report/domains/<month>/", methods=["GET"])
def monthly_domains(month):
  return jsonify({})
ref

•   https://github.com/axios/axios/issues/690

总结

以上所述是小编给大家介绍axios 处理 302 状态码的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
获取Javscript执行函数名称的方法
Dec 22 Javascript
js读取本地excel文档数据的代码
Nov 11 Javascript
jQuery表格插件ParamQuery简单使用方法示例
Dec 05 Javascript
jquery教程ajax请求json数据示例
Jan 13 Javascript
Bootstrap每天必学之按钮(一)
Nov 24 Javascript
封装好的javascript前端分页插件pagination
Jan 04 Javascript
AngularJS使用ng-repeat和ng-if实现数据的删选显示效果示例【适用于表单数据的显示】
Dec 13 Javascript
json2.js 入门教程之使用方法与实例分析
Sep 14 Javascript
详解Vue快速零配置的打包工具——parcel
Jan 16 Javascript
koa socket即时通讯的示例代码
Sep 07 Javascript
Vue axios设置访问基础路径方法
Sep 19 Javascript
微信小程序实现倒计时功能
Nov 19 Javascript
vue.js中npm安装教程图解
Apr 10 #Javascript
vue实现验证码按钮倒计时功能
Apr 10 #Javascript
vue 微信授权登录解决方案
Apr 10 #Javascript
详解给Vue2路由导航钩子和axios拦截器做个封装
Apr 10 #Javascript
详解webpack 打包文件体积过大解决方案(code splitting)
Apr 10 #Javascript
Angular CLI在Angular项目中如何使用scss详解
Apr 10 #Javascript
vue2.0+koa2+mongodb实现注册登录
Apr 10 #Javascript
You might like
PHP4实际应用经验篇(2)
2006/10/09 PHP
PHP中使用数组指针函数操作数组示例
2014/11/19 PHP
php实现发送微信模板消息的方法
2015/03/07 PHP
php使用递归函数实现数字累加的方法
2015/03/16 PHP
php生成zip文件类实例
2015/04/07 PHP
Cookie跨域问题解决方案代码示例
2020/11/24 PHP
编辑浪子版表单验证类
2007/05/12 Javascript
Javascript操作cookie的函数代码
2012/10/03 Javascript
兼容Firefox的Javascript XSLT 处理XML文件
2014/12/31 Javascript
javascript变量声明实例分析
2015/04/25 Javascript
深入浅析JavaScript的API设计原则
2016/06/14 Javascript
react.js 翻页插件实例代码
2017/01/19 Javascript
Angular JS 生成动态二维码的方法
2017/02/23 Javascript
用纯Node.JS弹出Windows系统消息提示框实例(MessageBox)
2017/05/17 Javascript
深入理解JavaScript创建对象的多种方式以及优缺点
2017/06/01 Javascript
vue 文件目录结构详解
2017/11/24 Javascript
vue项目中使用vue-i18n报错的解决方法
2019/01/13 Javascript
微信小程序云开发实现云数据库读写权限
2019/05/17 Javascript
微信小程序登录态和检验注册过没的app.js写法
2019/05/22 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
2020/03/08 Javascript
js实现车辆管理系统
2020/08/26 Javascript
如何在JavaScript中使用localStorage详情
2021/02/04 Javascript
Python基于pygame实现的font游戏字体(附源码)
2015/11/11 Python
python实现红包裂变算法
2016/02/16 Python
Python turtle库绘制菱形的3种方式小结
2019/11/23 Python
python爬虫中PhantomJS加载页面的实例方法
2020/11/12 Python
Wolford法国官网:奥地利奢侈内衣品牌
2020/08/11 全球购物
潘多拉珠宝俄罗斯官方网上商店:PANDORA俄罗斯
2020/09/22 全球购物
大学生毕业求职的自我评价
2013/09/29 职场文书
超市客服工作职责
2014/06/11 职场文书
创先争优个人总结
2015/03/04 职场文书
2016消防宣传标语口号
2015/12/26 职场文书
2016学习全国教书育人楷模先进事迹心得体会
2016/01/21 职场文书
民事纠纷协议书
2016/03/23 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书
职业生涯规划书之大学四年
2019/08/07 职场文书