• 第十章 restframework——版本控制


    第十章 restframework——版本控制

    一、内置的版本控制类

    二、局部使用

    三、全局使用

    四、源码解析

    一、内置的版本控制类

    导入模块

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

    1.QueryParameterVersioning

    作用:

    基于url的get传参方式

    地址访问举例:

    /users?version=v1

    2.AcceptHeaderVersioning

    作用:

    基于 accept 请求头方式

    地址访问举例:

    Accept: application/json; version=1.0

    3.NamespaceVersioning

    作用:

    基于django路由系统的namespace

    地址访问举例:

    example.com/v1/users/

    4.URLPathVersioning

    作用:

    基于url的正则方式

    地址访问举例:

    /v1/users/

    urls.py

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

    views.py

    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)
         # 基于django内置,反向生成url
            # from django.urls import reverse
            # url2=reverse(viewname='ttt',kwargs={'version':'v2'})
            # print(url2)
    return Response('GET请求,响应内容')

    5.HostNameVersioning

    作用:

    基于主机名方法

    地址访问举例:

    v1.example.com

    二、局部使用

    #在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
    }

    四、源码解析

    #执行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)
  • 相关阅读:
    学习笔记-10
    学习笔记-9
    《网络攻防相关》
    微信小程序云开发不完全指北
    Burp Suite 入门教程(BURP SUITE TUTORIAL )
    kali linux fuzz工具集简述
    kali linux Burp Suite极简使用教程
    kali linux web程序集简述
    kali linux 数据库分析工具简述
    kali linux 64bit 2019.1a下启动bbqsql:No module named coros
  • 原文地址:https://www.cnblogs.com/neymargoal/p/9839566.html
Copyright © 2020-2023  润新知