rest_framework:版本控制

Posted yangzhaon

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rest_framework:版本控制相关的知识,希望对你有一定的参考价值。

一、作用:

用于版本的控制,区分不同的功能,对于一些新增功能的添加更新就会在新的版本中体现,有点类似于,新版本就是软件发布的新版本,和老版本相比新增或者修改了一些功能

二、内置的版本控制类:

from rest_framework.versioning import QueryParameterVersioning,AcceptHeaderVersioning,NamespaceVersioning,URLPathVersioning

#基于url的get传参方式:QueryParameterVersioning------>如:/users?version=v1
#基于url的正则方式:URLPathVersioning------>/v1/users/
#基于 accept 请求头方式:AcceptHeaderVersioning------>Accept: application/json; version=1.0
#基于主机名方法:HostNameVersioning------>v1.example.com
#基于django路由系统的namespace:NamespaceVersioning------>example.com/v1/users/

三、局部使用:

#在CBV类中加入
versioning_class = URLPathVersioning

四:全局使用:

REST_FRAMEWORK = 
    DEFAULT_VERSIONING_CLASS:rest_framework.versioning.QueryParameterVersioning,
    DEFAULT_VERSION: v1,            # 默认版本(从request对象里取不到,显示的默认值)
    ALLOWED_VERSIONS: [v1, v2],   # 允许的版本
    VERSION_PARAM: version          # URL中获取值的key

五:范例

基于正则表达式:

路由:

from django.conf.urls import url, include
from web.views import TestView

urlpatterns = [
    url(r^(?P<version>[v1|v2]+)/test/, TestView.as_view(), name=test),
]

视图:

from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.versioning import URLPathVersioning


class TestView(APIView):
    versioning_class = URLPathVersioning

    def get(self, request, *args, **kwargs):
        # 获取版本
        print(request.version)
        # 获取版本管理的类
        print(request.versioning_scheme)

        # 反向生成URL
        reverse_url = request.versioning_scheme.reverse(test, request=request)
        print(reverse_url)

        return Response(GET请求,响应内容)
        # 基于django内置,反向生成url
        from django.urls import reverse
        url2=reverse(viewname=ttt,kwargs=version:v2)
        print(url2)

源码分析:

#执行determine_version,返回两个值,放到request对象里
version, scheme = self.determine_version(request, *args, **kwargs)
request.version, request.versioning_scheme = version, scheme

def determine_version(self, request, *args, **kwargs):
        #当配置上版本类之后,就会实例化
        if self.versioning_class is None:
            return (None, None)
        scheme = self.versioning_class()
        return (scheme.determine_version(request, *args, **kwargs), scheme)

 

以上是关于rest_framework:版本控制的主要内容,如果未能解决你的问题,请参考以下文章

版本,认证,权限

rest_framework:url控制

rest_framework-版本-总结完结篇

python学习第九十九天:版本控制 渲染器 分页器

版本组件

django rest_framework中将json输出字符强制为utf-8编码