如何實(shí)現(xiàn)Django Rest framework版本控制
前言
首先,我們開(kāi)發(fā)的項(xiàng)目會(huì)有多個(gè)版本.
其次,我們的項(xiàng)目版本會(huì)隨著更新越來(lái)越多,我們不可能因出了新版本就不維護(hù)舊版本了.
那么,我們就需要對(duì)版本進(jìn)行控制——DRF版本控制.
源碼剖析
DRF視圖中的APIView返回的是View類中的view函數(shù),然后調(diào)用dispatch方法.
那么,我們來(lái)看看dispatch方法都做了些什么:
執(zhí)行self.initial方法之前是各種賦值,包括request的重新封裝賦值.
self.initial方法中有路由的分發(fā),我們?cè)賮?lái)看下此方法具體都做了些什么:
我們可以看到:
==version版本信息賦值給了request.version.==
==scheme版本控制方案賦值給了request.versioning_scheme.==
其實(shí)這個(gè)版本控制方法就是我們配置的版本控制的類.
也就是說(shuō),APIView通過(guò)這個(gè)方法初始化自己提供的組件.
我們接下來(lái)看看rest_framework為我們提供了那些版本控制的方法(在from rest_framework import versioning文件內(nèi)):
如上,rest_framework為我們提供的所有版本控制的方法.
下面,我們來(lái)看看在URL上攜帶版本信息的用法.
使用內(nèi)置的URLPathVersioning類
如上圖所有示,URLPathVersioning是在url上攜帶版本信息的方法.
步驟一 setting.py
REST_FRAMEWORK = { 'DEFAULT_VERSIONING_CLASS': 'rest_framework.versioning.URLPathVersioning', # 指定使用的版本控制類 'ALLOWED_VERSIONS': ['v1', 'v2'], # 允許的版本 'VERSION_PARAM': 'version', # 版本使用的參數(shù)名稱 'DEFAULT_VERSION': 'v1', # 默認(rèn)使用的版本 }
步驟二 urls.py
from django.conf.urls import url from blog.views import Test01View # 導(dǎo)入視圖 urlpatterns = [ # 如下路徑形式: url(r'^(?P<version>[v1|v2]+)/test01', Test01View.as_view()), ]
步驟三 views.py
from rest_framework.views import APIView from rest_framework.response import Response class Test01View(APIView): def get(self, request, *args, **kwargs): print("版本:", kwargs['version']) print("版本控制信息:", request.versioning_scheme) if request.version == 'v1': # 處理版本v1的業(yè)務(wù)邏輯 return Response("這是版本v1的信息") # 處理版本v2的業(yè)務(wù)邏輯 return Response("這是版本v2的信息")
測(cè)試效果如下圖:
使用自定義的版本控制類
步驟一 創(chuàng)建自定義版本控制類
class MyVersion(): def determine_version(self, request, *args, **kwargs): # 返回值是版本號(hào) # 獲取前端傳過(guò)來(lái)的版本號(hào) 并且把版本號(hào)返回 version = request.query_params.get('version') if not version: # 默認(rèn)為版本v1,否則都為版本v2 version = 'v1' return version
步驟二 setting.py
REST_FRAMEWORK = { 'DEFAULT_VERSIONING_CLASS': 'utils.version.MyVersion', # 指定自定義的版本控制類 'ALLOWED_VERSIONS': ['v1', 'v2'], # 允許的版本 'VERSION_PARAM': 'version', # 版本使用的參數(shù)名稱 'DEFAULT_VERSION': 'v1', # 默認(rèn)使用的版本 }
步驟三 urls.py
from blog.views import Test02View # 導(dǎo)入視圖 urlpatterns = [ # 如下路徑格式 url(r'^test02/$', Test02View.as_view()), ]
步驟四 views.py
from rest_framework.views import APIView from rest_framework.response import Response class Test02View(APIView): def get(self, request): print("版本:", request.version) print("版本控制信息:", request.versioning_scheme) if request.version == 'v2': # 處理版本v2的業(yè)務(wù)邏輯 return Response("這是版本v2的信息") # 處理版本v1的業(yè)務(wù)邏輯 return Response("這是版本v1的信息")
測(cè)試效果如下圖:
is ok.
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用random.shuffle()隨機(jī)打亂字典排序
本文主要介紹了Python使用random.shuffle()隨機(jī)打亂字典排序,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08Python雙向循環(huán)鏈表實(shí)現(xiàn)方法分析
這篇文章主要介紹了Python雙向循環(huán)鏈表,結(jié)合實(shí)例形式分析了Python雙向鏈表的定義、遍歷、添加、刪除、搜索等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07python實(shí)現(xiàn)手機(jī)通訊錄搜索功能
這篇文章主要介紹了python模仿手機(jī)通訊錄搜索功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02Python與C語(yǔ)言分別解決完全平方數(shù)問(wèn)題
完全平方數(shù)指用一個(gè)整數(shù)乘以自己例如1*1.2*2.3*3等依次類推,若一個(gè)數(shù)能表示成某個(gè)整數(shù)的平方的形式,則稱這個(gè)數(shù)為完全平方數(shù)。完全平方數(shù)是非負(fù)數(shù),而一個(gè)完全平方數(shù)的項(xiàng)有倆個(gè),讓我們用程序來(lái)練習(xí)一下2022-03-03python中print的不換行即時(shí)輸出的快速解決方法
下面小編就為大家?guī)?lái)一篇python中print的不換行即時(shí)輸出的快速解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考2016-07-07python統(tǒng)計(jì)字符的個(gè)數(shù)代碼實(shí)例
在本篇文章里小編給大家整理了關(guān)于python統(tǒng)計(jì)字符的個(gè)數(shù)代碼實(shí)例內(nèi)容,需要的朋友們可以參考下。2020-02-02django限制匿名用戶訪問(wèn)及重定向的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于django限制匿名用戶訪問(wèn)及重定向的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-02-02python中的位置參數(shù)和關(guān)鍵字參數(shù)詳解
位置參數(shù)和關(guān)鍵字參數(shù)是 Python 中的兩種不同類型的函數(shù)參數(shù)傳遞方式,位置參數(shù)依賴于參數(shù)的位置順序,而關(guān)鍵字參數(shù)通過(guò)參數(shù)名傳遞,不受位置影響,本文通過(guò)代碼示例給大家詳細(xì)介紹了python中的位置參數(shù)和關(guān)鍵字參數(shù),需要的朋友可以參考下2023-12-12