溫馨提示×

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

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

怎么實(shí)現(xiàn)Django Rest framework版本控制

發(fā)布時(shí)間:2021-02-03 13:36:24 來(lái)源:億速云 閱讀:227 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)怎么實(shí)現(xiàn)Django Rest framework版本控制的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

前言

首先,我們開(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方法都做了些什么:

怎么實(shí)現(xiàn)Django Rest framework版本控制

執(zhí)行self.initial方法之前是各種賦值,包括request的重新封裝賦值.

self.initial方法中有路由的分發(fā),我們?cè)賮?lái)看下此方法具體都做了些什么:

怎么實(shí)現(xiàn)Django Rest framework版本控制

我們可以看到:

==version版本信息賦值給了request.version.==

==scheme版本控制方案賦值給了request.versioning_scheme.==

其實(shí)這個(gè)版本控制方法就是我們配置的版本控制的類.

也就是說(shuō),APIView通過(guò)這個(gè)方法初始化自己提供的組件.

我們接下來(lái)看看rest_framework為我們提供了那些版本控制的方法(在from rest_framework import versioning文件內(nèi)):

怎么實(shí)現(xiàn)Django Rest framework版本控制

如上,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è)試效果如下圖:

怎么實(shí)現(xiàn)Django Rest framework版本控制

怎么實(shí)現(xiàn)Django Rest framework版本控制

使用自定義的版本控制類

步驟一 創(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è)試效果如下圖:

怎么實(shí)現(xiàn)Django Rest framework版本控制

怎么實(shí)現(xiàn)Django Rest framework版本控制

怎么實(shí)現(xiàn)Django Rest framework版本控制

感謝各位的閱讀!關(guān)于“怎么實(shí)現(xiàn)Django Rest framework版本控制”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

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

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

AI