axios 處理 302 狀態(tài)碼的解決方法
比如說(shuō)瀏覽器打開(kāi)了一個(gè)單頁(yè)面(SPA)應(yīng)用,過(guò)了一段時(shí)間token(或者session)過(guò)期了,這個(gè)時(shí)候頁(yè)面上發(fā)起 Ajax請(qǐng)求之后,后端返回302狀態(tài)碼跳轉(zhuǎn)到login頁(yè)面。 我這是使用的是 Vue + axios ,發(fā)現(xiàn) axios 無(wú)法攔截到 302請(qǐng)求,下面是處理的過(guò)程。
思考
google axios 302 handle 看到 axios github 上的兩個(gè)討論
• https://github.com/axios/axios/issues/932
• https://github.com/axios/axios/issues/980
得到的結(jié)論就是:瀏覽器發(fā)送的ajax請(qǐng)求,服務(wù)端返回了302狀態(tài)碼,瀏覽器會(huì)自行跳轉(zhuǎn),我們無(wú)法通過(guò) js 庫(kù)(jquery, axios) 直接得到并自定義處理流程,只能等到瀏覽器重定向之后的url獲取相應(yīng)信息。
axios 發(fā)送ajax -->
server 返回302和location -->
瀏覽器請(qǐng)求新的url -->
服務(wù)端返回200 -->axios 獲取結(jié)果
那么怎么解決呢?需要服務(wù)端配合解決
Brower (ajax and not auth) -->
server判斷是ajax請(qǐng)求,未登陸,返回 401狀態(tài)碼 -->
瀏覽器 axios 攔截401,并且通過(guò)js 跳轉(zhuǎn)到 /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框架,看個(gè)流程就行,驗(yàn)證請(qǐng)求是否是 ajax 和 未登陸,然后返回401狀態(tài)碼
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
總結(jié)
以上所述是小編給大家介紹axios 處理 302 狀態(tài)碼的解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Javascript實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了Javascript實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
JS異步文件分片斷點(diǎn)上傳的實(shí)現(xiàn)思路
在項(xiàng)目中有時(shí)會(huì)遇到大文件上傳,經(jīng)常會(huì)出現(xiàn)鏈接超時(shí)的問(wèn)題,所以就需要使用文件分片上傳的方式來(lái)上傳大文件。下面通過(guò)本文給大家介紹js異步文件分片斷點(diǎn)上傳的實(shí)例代碼,需要的的朋友參考下吧2016-12-12
JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片翻轉(zhuǎn)的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片翻轉(zhuǎn)的方法,涉及javascript操作圖片與數(shù)組的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04

