程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
您现在的位置: 程式師世界 >> 編程語言 >  >> 更多編程語言 >> Python

Django視圖(四)

編輯:Python

目錄

一、類視圖

1.類視圖的使用

2.類視圖的多繼承重寫dispatch

二、中間件

1 .中間件的定義方法

2 .多個中間件的執行順序


一、類視圖

1.類視圖的使用

在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'),
]

2.類視圖的多繼承重寫dispatch

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處理視圖的不同階段對輸入或輸出進行干預。

1 .中間件的定義方法

定義一個中間件工廠函數,然後返回一個可以被調用的中間件。

中間件工廠函數需要接收一個可以調用的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部分有可能被調用兩次。

2 .多個中間件的執行順序

  • 在請求視圖被處理,中間件由上至下依次執行
  • 在請求視圖被處理,中間件由下至上依次執行

示例:

定義兩個中間件

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 被調用

  1. 上一篇文章:
  2. 下一篇文章:
Copyright © 程式師世界 All Rights Reserved