REST-framework之版本控制
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',
# 默认版本(从request对象里取不到,显示的默认值)
'DEFAULT_VERSION': 'v1',
# 允许的版本
'ALLOWED_VERSIONS': ['v1', 'v2'],
# URL中获取值的key
'VERSION_PARAM': 'version'
}
五 示例
基于正则的方式:
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)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现