首先咱们要知道咱们的版本是干吗用的呢~~你们都知道咱们开发项目是有多个版本的~~框架
当咱们项目愈来愈更新~版本就愈来愈多~~咱们不可能新的版本出了~之前旧的版本就不进行维护了~~~ide
那咱们就须要对版本进行控制~~这个DRF也给咱们提供了一些封装好的版本控制方法~~函数
以前咱们学视图的时候知道APIView,也知道APIView返回View中的view函数,而后调用的dispatch方法~url
那咱们如今看下dispatch方法~~看下它都作了什么~~spa
执行self.initial方法以前是各类赋值,包括request的从新封装赋值,下面是路由的分发,那咱们看下这个方法都作了什么~~版本控制
咱们能够看到,咱们的version版本信息赋值给了 request.version 版本控制方案赋值给了 request.versioning_scheme~~rest
其实这个版本控制方案~就是咱们配置的版本控制的类~~code
也就是说,APIView经过这个方法初始化本身提供的组件~~blog
咱们接下来看看框架提供了哪些版本的控制方法~~在rest_framework.versioning里~~路由
框架一共给咱们提供了这几个版本控制的方法~~咱们在这里只演示一个~~由于基本配置都是同样的~~
1 REST_FRAMEWORK = { 2 # 默认使用的版本控制类 3 'DEFAULT_VERSIONING_CLASS': 'rest_framework.versioning.URLPathVersioning', 4 # 容许的版本 5 'ALLOWED_VERSIONS': ['v1', 'v2'], 6 # 版本使用的参数名称 7 'VERSION_PARAM': 'version', 8 # 默认使用的版本 9 'DEFAULT_VERSION': 'v1', 10 }
1 urlpatterns = [ 2 url(r"^versions", MyView.as_view()), 3 url(r"^(?P<version>[v1|v2]+)/test01", TestView.as_view()), 4 ]
1 class TestView(APIView): 2 def get(self, request, *args, **kwargs): 3 print(request.versioning_scheme) 4 ret = request.version 5 if ret == "v1": 6 return Response("版本v1的信息") 7 elif ret == "v2": 8 return Response("版本v2的信息") 9 else: 10 return Response("根本就匹配不到这个路由")