目錄
一、類視圖
1.類視圖的使用
2.類視圖的多繼承重寫dispatch
二、中間件
1 .中間件的定義方法
2 .多個中間件的執行順序
在Django中也可以使用類來定義一個視圖,稱為類視圖。
使用類視圖可以將視圖對應的不同請求方式以類中的不同方法來區別定義。如下所示
from django.views.generic import View
class RegisterView(View):
"""類視圖:處理注冊"""
def get(self, request):
"""處理GET請求,返回注冊頁面"""
return render(request, 'register.html')
def post(self, request):
"""處理POST請求,實現注冊邏輯"""
return HttpResponse('這裡實現注冊邏輯')
類視圖的好處:
定義類視圖需要繼承自Django提供的父類View,可使用from django.views.generic import View
或者from django.views.generic.base import View
導入,定義方式如上所示。
配置路由時,使用類視圖的as_view()
方法來添加。
urlpatterns = [
# 視圖函數:注冊
# url(r'^register/$', views.register, name='register'),
# 類視圖:注冊
url(r'^register/$', views.RegisterView.as_view(), name='register'),
]
class CenterView(View):
def get(self,request):
return HttpResponse("OK")
def post(self,request):
return HttpResponse("OK")
使用面向對象多繼承的特性。
class CenterView(LoginRequireMixin,View):
def get(self,request):
return HttpResponse("OK")
def post(self,request):
return HttpResponse("OK")
Django中的中間件是一個輕量級、底層的插件系統,可以介入Django的請求和響應處理過程,修改Django的輸入或輸出。中間件的設計為開發者提供了一種無侵入式的開發方式,增強了Django框架的健壯性。
我們可以使用中間件,在Django處理視圖的不同階段對輸入或輸出進行干預。
定義一個中間件工廠函數,然後返回一個可以被調用的中間件。
中間件工廠函數需要接收一個可以調用的get_response對象。
返回的中間件也是一個可以被調用的對象,並且像視圖一樣需要接收一個request對象參數,返回一個response對象。
def simple_middleware(get_response):
# 此處編寫的代碼僅在Django第一次配置和初始化的時候執行一次。
def middleware(request):
# 此處編寫的代碼會在每個請求處理視圖前被調用。
response = get_response(request)
# 此處編寫的代碼會在每個請求處理視圖之後被調用。
return response
return middleware
例如,在book應用中新建一個middleware.py文件,
def my_middleware(get_response):
print('init 被調用')
def middleware(request):
print('before request 被調用')
response = get_response(request)
print('after response 被調用')
return response
return middleware
定義好中間件後,需要在settings.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',
'book.middleware.my_middleware', # 添加中間件
]
定義一個視圖進行測試
def middleware(request):
print('view 視圖被調用')
return HttpResponse('OK')
執行結果
注意:Django運行在調試模式下,中間件init部分有可能被調用兩次。
示例:
定義兩個中間件
def my_middleware(get_response):
print('init 被調用')
def middleware(request):
print('before request 被調用')
response = get_response(request)
print('after response 被調用')
return response
return middleware
def my_middleware2(get_response):
print('init2 被調用')
def middleware(request):
print('before request 2 被調用')
response = get_response(request)
print('after response 2 被調用')
return response
return middleware
注冊添加兩個中間件
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',
'users.middleware.my_middleware', # 添加
'users.middleware.my_middleware2', # 添加
]
執行結果
init2 被調用
init 被調用
before request 被調用
before request 2 被調用
view 視圖被調用
after response 2 被調用
after response 被調用