版本的使用

  1. 第一步:写路由url(r'^api/(P<version>\w+)/user/$',views.UserView.as_view()),
  2. 第二步:写模块导入from rest_framework.versioning import URLPathVersioning
  3. 第三步:写视图 可不写
  4. request.version获取版本号
  5. class UserView(APIView): # DEFAULT_VERSIONING_CLASS在APIView中默认配置
  6. def get(self,request,*args,**kwargs):
  7. print(request.version)
  8. return Response('....')
  9. 第四步:写settings配置:
  10. REST_FRAMEWORK = {
  11. "DEFAULT_VERSIONING_CLASS": "rest_framework.versioning.URLPathVersioning", #配置全局的版本信息
  12. "ALLOWED_VERSIONS":['v1','v2'] #配置允许版本号范围
  13. }

版本的源码分析

执行流程

  1. 1.请求进来执行dispatch方法中的initialize_request方法
  2. def initialize_request(self, request, *args, **kwargs):
  3. parser_context = self.get_parser_context(request)
  4. return Request(
  5. request,
  6. parsers=self.get_parsers(),
  7. authenticators=self.get_authenticators(),
  8. negotiator=self.get_content_negotiator(),
  9. parser_context=parser_context
  10. )
  11. #会对request对象进行重新封装,把老的request封装成新的request
  1. 2.接着执行initial方法
  2. def initial(self, request, *args, **kwargs):
  3. .......略过的代码,暂时与版本无关
  4. #版本相关的函数
  5. version, scheme = self.determine_version(request, *args, **kwargs)
  6. request.version, request.versioning_scheme = version, scheme
  7. self.perform_authentication(request)
  8. self.check_permissions(request)
  9. self.check_throttles(request)
  1. 3.执行determine_version方法
  2. def determine_version(self, request, *args, **kwargs):
  3. if self.versioning_class is None:
  4. return (None, None)
  5. scheme = self.versioning_class()
  6. return (scheme.determine_version(request, *args, **kwargs), scheme)
  7. #会调用versioning_class进行判断,默认为None,版本也就返回None,自我认为意义不大,version_class先去自己定义的类中找该方法,如果没有定义就去父类中找,父类中为None
  1. 4.如果自己的定义的版本类中有该方法,就执行scheme = self.versioning_class(),对自己定义的版本类进行实例化
  1. 5.执行determine_version返回值中的scheme.determine_version(request, *args, **kwargs)
  2. #这个scheme就是我们写的版本类
  1. 6.执行自定义的版本类中的determine_version
  2. def determine_version(self, request, *args, **kwargs):
  3. version = kwargs.get(self.version_param, self.default_version)
  4. if version is None: #判断version如果为None就会设置成默认的版本
  5. version = self.default_version
  6. if not self.is_allowed_version(version):#对版本号进行限制allowed_version,在settings中定义ALLOWD_VERSION=[V1,V2]
  7. raise exceptions.NotFound(self.invalid_version_message)
  8. return version
  9. # version_param就是一个字符串version,也就是URL中的版本号
  1. 7.限制版本号的函数
  2. def is_allowed_version(self, version):
  3. if not self.allowed_versions:# --->ALLOWD_VERSION=[V1,V2]
  4. return True
  5. return ((version is not None and version == self.default_version) or
  6. (version in self.allowed_versions))

概括

  1. 1.当请求进来时,先执行dispatch方法,执行initialize_requestrequest进行重新的封装
  2. 2.执行initial方法,执行版本相关函数:determine_version(request, *args, **kwargs)
  3. 3.determine_version方法中,会调用versioning_class进行判断,默认为None,版本也就返回None,意义不大
  4. 4.version_class先去自己定义的类中找该方法,如果没有定义就去父类中找,父类中为None
  5. 5.如果自己的定义的版本类中有该方法,就会执行scheme = self.versioning_class()进行实例化
  6. 6.接着就会执行返回值中的scheme.determine_version,scheme指的就是版本类
  7. 7.执行认证类中的determine_version方法..
  8. version = kwargs.get(self.version_param, self.default_version)
  9. version_param就是一个字符串version,也就是URL中的
  10. 8.接着会判断version如果为None就会设置成默认的版本
  11. 9.对版本号进行限制allowed_version,在settings中定义ALLOWD_VERSION=[V1,V2]

drf源码分析系列---版本控制的更多相关文章

  1. drf源码分析系列---节流(访问频率限制)

    使用 from rest_framework.throttling import AnonRateThrottle from rest_framework.generics import ListAP ...

  2. drf源码分析系列---权限

    权限的使用 全局使用 from rest_framework.permissions import BasePermission from rest_framework import exceptio ...

  3. drf源码分析系列---认证

    认证的使用 from rest_framework.authentication import BaseAuthentication from api import models # 认证类 clas ...

  4. jQuery源码分析系列

    声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://git ...

  5. jQuery-1.9.1源码分析系列完毕目录整理

    jQuery 1.9.1源码分析已经完毕.目录如下 jQuery-1.9.1源码分析系列(一)整体架构 jQuery-1.9.1源码分析系列(一)整体架构续 jQuery-1.9.1源码分析系列(二) ...

  6. MyCat源码分析系列之——结果合并

    更多MyCat源码分析,请戳MyCat源码分析系列 结果合并 在SQL下发流程和前后端验证流程中介绍过,通过用户验证的后端连接绑定的NIOHandler是MySQLConnectionHandler实 ...

  7. MyCat源码分析系列之——SQL下发

    更多MyCat源码分析,请戳MyCat源码分析系列 SQL下发 SQL下发指的是MyCat将解析并改造完成的SQL语句依次发送至相应的MySQL节点(datanode)的过程,该执行过程由NonBlo ...

  8. MyCat源码分析系列之——BufferPool与缓存机制

    更多MyCat源码分析,请戳MyCat源码分析系列 BufferPool MyCat的缓冲区采用的是java.nio.ByteBuffer,由BufferPool类统一管理,相关的设置在SystemC ...

  9. MyCat源码分析系列之——前后端验证

    更多MyCat源码分析,请戳MyCat源码分析系列 MyCat前端验证 MyCat的前端验证指的是应用连接MyCat时进行的用户验证过程,如使用MySQL客户端时,$ mysql -uroot -pr ...

随机推荐

  1. PL真有意思(三):名字、作用域和约束

    前言 这两篇写了词法分析和语法分析,比较偏向实践.这一篇来看一下语言设计里一个比较重要的部分:名字.在大部分语言里,名字就是标识符,如果从抽象层面来看名字就是对更低一级的内存之类的概念的一层抽象.但是 ...

  2. 20191031-9 beta week 1/2 Scrum立会报告+燃尽图 07

    此作业要求参见https://edu.cnblogs.com/campus/nenu/2019fall/homework/9917 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 韩昊 ...

  3. 微信公众号配置及微信jsAPI支付

    公众号配置 一.基本配置 首先登陆微信公众平台,在开发--->配置--->公众号开发信息,获取到AppId,开发者秘钥是后台需要的,给到后台,IP白名单配置就是你服务器的IP地址写到里面就 ...

  4. Hadoop运行模式

    Hadoop运行模式 (1)本地模式(默认模式): 不需要启用单独进程,直接可以运行,测试和开发时使用. 即在一台机器上进行操作,仅为单机版. 本地运行Hadoop官方MapReduce案例 操作命令 ...

  5. Gemini.Workflow 双子工作流高级教程:数据库设计及各表作用说明

    整体数据库设计,可见这一篇:Gemini.Workflow 双子工作流高级教程:数据库-设计文档 这里对各数据表进行介绍: 工作流里的设计表并不多,核心只有以下8个: 下面按照流程的顺序来介绍一下表的 ...

  6. vim的各项指令

    lesson1 <ESC> 保证进入正常模式 :q!回车   退出编辑器 x 删除光标所在的字母 i 添加内容 A 自动追加内容到行尾 :wq 保存文件并退出 lesson2 dw 删除某 ...

  7. 使用IDEA创建SpringMVC项目

    作为一名从.NET转Java的小渣渣,之前都是听说Java配置复杂,今天算是见识到了.甚是怀念宇宙第一IDE VS和.NET高效的开发. 网上大多教程是基于Eclipse的,即使按照IDEA的教程做, ...

  8. SpringMVC配置了拦截器(interceptors)却显示不出css、js样式的解决办法

    首先因为在web.xml里面配置了 <filter-mapping> <filter-name>characterEncodingFilter</filter-name& ...

  9. MySQL5.6.36 自动化安装脚本

    背景 很好的朋友邱启明同学,擅长MySQL,目前任职某大型互联网业MySQL DBA,要来一套MySQL自动安装的Shell脚本,贴出来保存一些. 此版本为 MySQL 5.6.365 ###### ...

  10. Vue项目功能插件

    项目功能插件 vue-router { path: '/', name: 'home', // 路由的重定向 redirect: '/home' } { // 一级路由, 在根组件中被渲染, 替换根组 ...