溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Django中間件

發(fā)布時間:2020-09-17 09:35:04 來源:網(wǎng)絡(luò) 閱讀:327 作者:LeslieLiang 欄目:編程語言

django的中間件可以在視圖函數(shù)執(zhí)行前執(zhí)行,比如登陸驗證、日志記錄等,下面簡單說明一下中間件的基礎(chǔ)用法,主要為筆者學(xué)習(xí)時的筆記

1. 在django項目文件夾下創(chuàng)建一個用于存放中間件函數(shù)的文件夾

文件夾的名字可自定義,本文使用utils作為文件夾名

2. 在utils文件夾中創(chuàng)建中間件py文件

如用于登陸驗證的中間件loginCheck.py

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

class UserLoginCheck(MiddlewareMixin):
    '''
    登錄驗證中間件
    '''
    def process_request(self, request):
        # 用戶request請求前
        path = ['/login/', '/logout/'] # 不需要進(jìn)行登錄檢測的url
        if request.path in path:
            return

        userinfoSession = request.session.get('userinfo')
        if not userinfoSession:
            return HttpResponseRedirect('/login/')
        return
3. 配置使用中間件

setting.py文件中配置中間件

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'utils.loginCheck.UserLoginCheck', # 此處為自定義的中間件
]
擴展

中間件可定義的五種方法
Request預(yù)處理函數(shù): process_request(self, request)

  • 這個方法的調(diào)用時機在Django接收到request之后,但仍未解析URL以確定應(yīng)當(dāng)運行的視圖函數(shù)。Django向它傳入相應(yīng)的Request對象,以便在方法中修改。
  • 如果返回None,Django將繼續(xù)處理這個request,執(zhí)行后續(xù)的中間件, 然后調(diào)用相應(yīng)的 view。
  • 如果返回HttpResponse對象,Django將不再執(zhí)行任何除了process_response以外其它的中間件以及相應(yīng)的view,Django將立即返回該HttpResponse。

View預(yù)處理函數(shù): process_view(self, request, callback, callback_args,callback_kwargs)

  • 這個方法的調(diào)用時機在 Django 執(zhí)行完 request 預(yù)處理函數(shù)并確定待執(zhí)行的 view (即callback參數(shù))之后,但在 view 函數(shù)實際執(zhí)行之前。
  • request:HttpRequest 對象。
  • callback:Django將調(diào)用的處理request的python函數(shù). 這是實際的函數(shù)對象本身, 而不是字符串表述的函數(shù)名。
  • args:將傳入view的位置參數(shù)列表,但不包括request參數(shù)(它通常是傳入view的第一個參數(shù))。
  • kwargs:將傳入view的關(guān)鍵字參數(shù)字典。
  • process_view() 應(yīng)當(dāng)返回None或 HttpResponse 對象。如果返回 None, Django將繼續(xù)處理這個request ,執(zhí)行后續(xù)的中間件, 然后調(diào)用相應(yīng)的view。
  • 如果返回 HttpResponse 對象,Django 將不再執(zhí)行任何其它的中間件(不論種類)以及相應(yīng)的view,Django將立即返回。

Template模版渲染函數(shù):process_template_response()

  • 默認(rèn)不執(zhí)行,只有在視圖函數(shù)的返回結(jié)果對象中有render方法才會執(zhí)行,并把對象的render方法的返回值返回給用戶(注意不返回視圖函數(shù)的return的結(jié)果了,而是返回視圖函數(shù) return值(對象)中rende方法的結(jié)果)

Exception后處理函數(shù):process_exception(self, request, exception)

  • 這個方法只有在 request 處理過程中出了問題并且view 函數(shù)拋出了一個未捕獲的異常時才會被調(diào)用。這個鉤子可以用來發(fā)送錯誤通知,將現(xiàn)場相關(guān)信息輸出到日志文件,或者甚至嘗試從錯誤中自動恢復(fù)。
  • 這個函數(shù)的參數(shù)除了一貫的request對象之外,還包括view函數(shù)拋出的實際的異常對象exception 。
  • process_exception() 應(yīng)當(dāng)返回None或HttpResponse對象。
  • 如果返回None,Django將用框架內(nèi)置的異常處理機制繼續(xù)處理相應(yīng)request。
  • 如果返回HttpResponse對象,Django將使用該response對象,而短路框架內(nèi)置的異常處理機制。

Response后處理函數(shù):process_response(self, request, response)

  • 這個方法的調(diào)用時機在 Django 執(zhí)行 view 函數(shù)并生成 response 之后。
  • 該處理器能修改response 的內(nèi)容;一個常見的用途是內(nèi)容壓縮,如gzip所請求的HTML頁面。
  • 這個方法的參數(shù)相當(dāng)直觀:request是request對象,而response則是從view中返回的response對象。
  • process_response() 必須返回 HttpResponse 對象. 這個 response 對象可以是傳入函數(shù)的那一個原始對象(通常已被修改),也可以是全新生成的。

參考資料:https://baijiahao.baidu.com/s?id=1622776730103957680

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI