axios 处理 302 状态码的解决方法
比如说浏览器打开了一个单页面(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 状态码的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
- [转]ASP.NET MVC Json()处理大数据异常解决方法 json maxjsonlength
- 用事件队列解决GUI的操作顺序问题(Qt中处理方法)
- sqlite3 jdbc、c接口、python接口处理中文时遇到的问题及其解决方法
- PyQt中处理信号和槽时遇到的问题和解决方法
- axios发送post请求springMVC接收不到参数的解决方法
- 鼠标右键失效的处理解决方法
- 解决大文件的读取、存储等处理的方法
- zt:mina源码经maven2处理后,导入eclipse有Unbound classpath variable: 'M2_REPO报错的解决方法
- 解决方法: A C3P0Registry mbean is already registered.This probably means that an application using c3p0的警告信息处理
- http请求 302解决方法
- php5.2 Json不能正确处理中文、GB编码的解决方法
- LaTex “too many unprocessed floats” (过多未处理的浮动)错误的解决方法
- 1229处理既含有中文又含有英文字符的字符串的相关程序解决方法
- hadoop 安装出现的几种异常的处理方法,hadoop无法启动,no namenode to stop问题的解决方法,no datanode
- java各种处理字符串情况乱码原因分析及其解决方法
- Android 异步获取网络图片并处理导致内存溢出问题解决方法
- SD高清图片处理--内存疯长解决方法
- win8.1 OllyICE 调试的程序无法处理异常 解决方法
- ASP.NET MVC Json()处理大数据异常解决方法
- IEXPLORE.EXE[...]发生未处理的WIN32异常解决方法分享