如何實(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)文章
tensorflow通過(guò)模型文件,使用tensorboard查看其模型圖Graph方式
今天小編就為大家分享一篇tensorflow通過(guò)模型文件,使用tensorboard查看其模型圖Graph方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
基于OpenCv實(shí)現(xiàn)的人臉識(shí)別(附Python完整代碼)
人臉識(shí)別是基于人的臉部特征信息進(jìn)行身份識(shí)別的一種生物識(shí)別技術(shù),下面這篇文章主要給大家介紹了關(guān)于如何基于OpenCv實(shí)現(xiàn)的人臉識(shí)別,文中還附Python完整代碼,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11
從零開(kāi)始制作PyTorch的Singularity容器鏡像的解決方案
本文主要介紹Facebook所主導(dǎo)的機(jī)器學(xué)習(xí)框架PyTorch的容器化安裝方法,基于HPC環(huán)境常用的Singularity高性能容器,并且兼容與結(jié)合了Docker容器鏡像的生態(tài),感興趣的朋友跟隨小編一起看看吧2024-05-05
flask 實(shí)現(xiàn)上傳圖片并縮放作為頭像的例子
今天小編就為大家分享一篇flask 實(shí)現(xiàn)上傳圖片并縮放作為頭像的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
Python制作簡(jiǎn)易注冊(cè)登錄系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Python簡(jiǎn)易注冊(cè)登錄系統(tǒng)的制作方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
kaggle+mnist實(shí)現(xiàn)手寫(xiě)字體識(shí)別
這篇文章主要為大家詳細(xì)介紹了kaggle+mnist實(shí)現(xiàn)手寫(xiě)字體識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07

