DRF的版本控制

DRF的版本

版本控制是作什么用的, 咱们为何要用

  首先咱们要知道咱们的版本是干吗用的呢~~你们都知道咱们开发项目是有多个版本的~~框架

当咱们项目愈来愈更新~版本就愈来愈多~~咱们不可能新的版本出了~之前旧的版本就不进行维护了~~~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 }
第一步 settings.py
1 urlpatterns = [
2     url(r"^versions", MyView.as_view()),
3     url(r"^(?P<version>[v1|v2]+)/test01", TestView.as_view()),
4 ]
第二步 urls.py
 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("根本就匹配不到这个路由")
第三步 视图
相关文章
相关标签/搜索