濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Django中間件整合Vue攔截器的使用

Django中間件整合Vue攔截器的使用

熱門標(biāo)簽:萊蕪電信外呼系統(tǒng) 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)違法嗎 銀川電話機(jī)器人電話 B52系統(tǒng)電梯外呼顯示E7 高德地圖標(biāo)注收入咋樣 怎么辦理400客服電話 地圖標(biāo)注多個(gè) 沈陽防封電銷電話卡 企業(yè)微信地圖標(biāo)注

axios攔截器是什么?

axios攔截器可以攔截每一次的請(qǐng)求和響應(yīng),然后進(jìn)行相應(yīng)的處理。攔截器分為請(qǐng)求攔截器和響應(yīng)攔截器,請(qǐng)求攔截器可以統(tǒng)一在你發(fā)送請(qǐng)求前在請(qǐng)求體里加上token;響應(yīng)攔截器的話,是在接受到響應(yīng)之后進(jìn)行的一些操作,比如,服務(wù)器返回登錄狀態(tài)失效,需要重新登錄的時(shí)候,就給它跳到登錄頁(yè)面;

攔截器的使用

我一般喜歡全局配置(main.js)

請(qǐng)求攔截器

//  interceptors
axios.interceptors.request.use(
  config => {
 // 獲取登錄成功狀態(tài)保持的token
    let token = localStorage.getItem('token')
 // 如果有token就在頭部加上token
    if (token) {
      config.headers['Authorization'] = token
    }
    return config
  },
  error => {
 // 如果沒有token,返回錯(cuò)誤的信息
    return Promise.reject(error.response);
  });

響應(yīng)攔截器

axios.interceptors.response.use(function (response) {
    // 在接收響應(yīng)做些什么,例如跳轉(zhuǎn)到登錄頁(yè)
    ......
    return response;
  }, function (error) {
    // 對(duì)響應(yīng)錯(cuò)誤做點(diǎn)什么
    return Promise.reject(error);
  });

攔截器超級(jí)好用~~~

Django中間件token驗(yàn)證

中間件相關(guān)

中間件是一個(gè)用來處理Django的請(qǐng)求和響應(yīng)的框架級(jí)別的鉤子。它是一個(gè)輕量、低級(jí)別的插件系統(tǒng),用于在全局范圍內(nèi)改變Django的輸入和輸出。每個(gè)中間件組件都負(fù)責(zé)做一些特定的功能。但是由于其影響的是全局,所以需要謹(jǐn)慎使用,使用不當(dāng)會(huì)影響性能。說的直白一點(diǎn),中間件是幫助我們?cè)谝晥D函數(shù)執(zhí)行之前和執(zhí)行之后都可以做一些額外的操作,它本質(zhì)上就是一個(gè)自定義類,類中定義了幾個(gè)方法,Django框架會(huì)在請(qǐng)求的特定的時(shí)間去執(zhí)行這些方法。

自定義中間件

中間件可以定義五個(gè)方法,分別是:(主要的是process_request和process_response)

  • process_request(self,request)
  • process_view(self, request, view_func, view_args, view_kwargs)
  • process_template_response(self,request,response)
  • process_exception(self, request, exception)
  • process_response(self, request, response)

以上方法的返回值可以是None或一個(gè)HttpResponse對(duì)象,如果是None,則繼續(xù)按照django定義的規(guī)則向后繼續(xù)執(zhí)行,如果是HttpResponse對(duì)象,則直接將該對(duì)象返回給用戶。

中間件的執(zhí)行流程

  請(qǐng)求到達(dá)中間件之后,先按照正序執(zhí)行每個(gè)注冊(cè)中間件的process_reques方法process_request方法返回的值是None,就依次執(zhí)行,如果返回的值是HttpResponse對(duì)象,不再執(zhí)行后面的process_request方法,而是執(zhí)行當(dāng)前對(duì)應(yīng)中間件的process_response方法。HttpResponse對(duì)象返回給瀏覽器。也就是說:如果MIDDLEWARE中注冊(cè)了6個(gè)中間件,執(zhí)行過程中,第3個(gè)中間件返回了一個(gè)HttpResponse對(duì)象,那么第4,5,6中間件的process_request和process_response方法都不執(zhí)行,順序執(zhí)行3,2,1中間件的process_response方法。

用中間件進(jìn)行登錄認(rèn)證

戰(zhàn)術(shù)喝水~~ 上代碼

# Author : Carl
# Date :2021/8/27 9:43
# File :tokenMiddleware.py

from django.http import HttpResponse
from django.utils.deprecation import MiddlewareMixin

import jwt

from meiduo import settings


class TokenMiddleware(MiddlewareMixin):
    """
    中間件生成Token
    """

    def process_request(self, request):
        """
        token認(rèn)證
        :param request:
        :return:token
        """
        # 獲取url
        url = request.get_full_path()
        # 定義一個(gè)白名單 注冊(cè)登錄接口 隨便訪問
        white_list = ['/sadmin/login/','/admin/']
        # 判斷url在不在白名單中
        if url not in white_list:
            # 獲取token jwttoken認(rèn)證去認(rèn)證
            token = request.META.get('HTTP_AUTHORIZATION')
            # 解析驗(yàn)證
            if token:
                # 解決原來的token
                old_token = jwt.decode(token, settings.SECRET_KEY, algorithms=['HS256'])
                # 重新生成token
                new_token = str(jwt.encode(old_token, settings.SECRET_KEY, algorithm='HS256'), encoding='utf8')
                if token == new_token:
                    return None
            return HttpResponse('401')
        return None
 

總結(jié)

在請(qǐng)求接口的時(shí)候,如果用戶沒有登錄,則在請(qǐng)求到達(dá)中間件時(shí)放行,加入視圖層,在視圖層進(jìn)行密碼手機(jī)號(hào),用戶名,密碼等的匹配,匹配成功之后,將生成的token返回到前端進(jìn)行狀態(tài)保持,使用攔截器在每一次請(qǐng)求的頭部加上token(狀態(tài)保持的token),由中間件對(duì)token進(jìn)行解析對(duì)比,對(duì)比成功則進(jìn)入視圖層,否則,返回401(沒有權(quán)限)。

到此這篇關(guān)于Django中間件整合Vue攔截器的使用的文章就介紹到這了,更多相關(guān)Django Vue攔截器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Django中間件實(shí)現(xiàn)攔截器的方法

標(biāo)簽:葫蘆島 呼倫貝爾 湘西 銀川 三亞 安慶 烏魯木齊 呼倫貝爾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django中間件整合Vue攔截器的使用》,本文關(guān)鍵詞  Django,中間件,整合,Vue,攔截,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django中間件整合Vue攔截器的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Django中間件整合Vue攔截器的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    白山市| 五台县| 白河县| 灌阳县| 磴口县| 盐池县| 丽水市| 泰宁县| 锡林郭勒盟| 苏尼特右旗| 遂溪县| 曲阳县| 武夷山市| 弥渡县| 承德市| 余干县| 江山市| 赣榆县| 文成县| 嘉义市| 黄骅市| 榆中县| 临洮县| 屏东县| 安岳县| 资溪县| 黑山县| 交口县| 波密县| 蛟河市| 万宁市| 伊宁市| 新乡县| 洮南市| 新民市| 巫山县| 湟中县| 武平县| 广饶县| 华安县| 深泽县|