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

网友投稿 1863 2023-02-09


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//", methods=["GET"])

def monthly_domains(month):

return jsonify({})

ref

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

总结

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:企业微信管理员已通过api接口(企业微信通过api管理通讯录)
下一篇:Angular CLI在Angular项目中如何使用scss详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~