首頁  >  文章  >  web前端  >  axios怎樣解決302狀態碼問題

axios怎樣解決302狀態碼問題

php中世界最好的语言
php中世界最好的语言原創
2018-05-25 14:15:444297瀏覽

這次帶給大家axios怎樣解決302狀態碼問題,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
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue的select內建元件使用步驟詳解

React使用時避免重渲染

以上是axios怎樣解決302狀態碼問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn