版本控制:

源码位置分析第一步:

源码位置分析第二步:在APIView-despath方法-initial-determine_version

#执行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)

代码实现:

settings配置

REST_FRAMEWORK={
# 'DEFAULT_RENDERER_CLASSES':['rest_framework.renderers.JSONRenderer'],
#url中获取值的key
'VERSION_PARAM':'version',
#默认版本(从request对象里取不到,显示的默认值版本号,例如:默认不写后台打印也是v2 http://127.0.0.1:8006/testversion/)
'DEFAULT_VERSION':'v2',
#允许的版本(只有写在列表里面的,浏览器访问才能输入响应的版本地址,例如:http://127.0.0.1:8006/v2/testversion/)
'ALLOWED_VERSIONS':['v1','v2']

路由设置:

#对应视图方式一: 
url(r'^testversion/', views.Test.as_view()),
#对应视图方式二:
url(r'^(?P<version>[v1|v2|v3]+)/testversion/', views.Test2.as_view(),name='ttt'),

视图设置:

from rest_framework.versioning import QueryParameterVersioning,URLPathVersioning
#情况一:
class Test(APIView):
#不再是列表
versioning_class=QueryParameterVersioning
def get(self,request,*args,**kwargs):
print(request.version) #v2 return Response('ok') #情况二:
from django.urls import reverse
class Test2(APIView):
  #不再是列表
versioning_class=URLPathVersioning
def get(self,request,*args,**kwargs):
     #获取版本
print(request.version) #v1
     #获取版本管理的类
print(request.versioning_scheme)
     #反向生成url
url=request.versioning_scheme.reverse(viewname='ttt',request=request)
print(url) #http://127.0.0.1:8006/v1/testversion/
url2=reverse(viewname='ttt',kwargs={'version':'v1'})
print(url2) #/v1/testversion/
return Response('ok ttest2')

分页器:

路由:

url(r'^page', views.Page.as_view()),

BookSer序列化所有书籍:

class BookSer(serializers.ModelSerializer):
class Meta:
model=models.Book
fields='__all__'

一 简单分页(查看第n页,每页显示n条)

1 简单分页
http://127.0.0.1:8006/page/?page=2&size=4
PageNumberPagination
#每页显示多少条api_settings.PAGE_SIZE
#page_size =
#查询指定页码的参数
#page_query_param = 'page'
#指定每页显示条数
#page_size_query_param = None
#限制每页显示最大条数
#max_page_size = None
#简单分页:PageNumberPagination
from rest_framework.pagination import PageNumberPagination,LimitOffsetPagination,CursorPagination
class Page(APIView):
def get(self,request,*args,**kwargs):
#获取所有数据
ret=models.Book.objects.all()
#创建分页对象
my_page=PageNumberPagination()
#默认每页显示条数
my_page.page_size=2
#指定每页显示条数(受下面最大显示条数的限制)
my_page.page_size_query_param='size'
#限制每页最大显示条数
my_page.max_page_size=5
#在数据库中获取分页数据
page_list=my_page.paginate_queryset(ret,request,self)
#对分页进行实例化
ser=BookSer(instance=page_list,many=True)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
每页显示多少条api_settings.PAGE_SIZE
page_size =
查询指定页码的参数
page_query_param = 'page'
指定每页显示条数
page_size_query_param = None
限制每页显示最大条数
max_page_size = None
'''
return Response(ser.data)

图解:

二 偏移分页(在第n个位置,向后查看n条数据)

偏移分页要点:
后台返回的url:http://127.0.0.1:8006/page?limit=3&offset=2
LimitOffsetPagination
default_limit:默认显示多少条
max_limit:最大显示多少条
limit_query_param:重新命名limit(limit=4:表明显示四条,受max_limit的限制)
offset_query_param:指定查询的标杆名(offset=1:表明从第二条开始,往后偏移)
#偏移分页:LimitOffsetPagination
# 也可以自定制,同简单分页
class Page(APIView):
def get(self,request,*args,**kwargs):
#获取所有数据
ret=models.Book.objects.all()
#创建分页而对象
my_page=LimitOffsetPagination()
my_page.default_limit=3
my_page.max_limit=5 #在数据库中获取分页的数据
page_list=my_page.paginate_queryset(ret,request,self)
#对分页进行序列化
ser=BookSer(instance=page_list,many=True)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
default_limit:默认显示多少条
max_limit:最大显示多少条
limit_query_param:重新命名limit(limit=4:表明显示四条,受max_limit的限制)
offset_query_param:指定查询的标杆名(offset=1:表明从第二条开始,往后偏移)
''' #只是显示指定访问的内容(不包含总条数和上、下页链接)
# return Response(ser.data) # 对Response做了封装,返回内容里有总条数,上一页,下一页的链接
return my_page.get_paginated_response(ser.data)

图解:

 

三 加密分页:CursorPagination(只能看上一页和下一页,速度快)

加密分页要点:
后台返回的url:例如 http://127.0.0.1:8006/page?cursor=cD0y(随机的字符串)
CursorPagination
cursor_query_param = 'cursor':查询的名字
page_size = api_settings.PAGE_SIZE:每页显示的条数
ordering = '-created' :按谁排序
#加密分页:CursorPagination
#看源码,是通过sql查询,大于id和小于id
class Page(APIView):
def get(self,request,*args,**kwargs):
#获取所有数据
ret=models.Book.objects.all()
#创建分页对象
my_page=CursorPagination()
#安装id就行排序
my_page.ordering='id'
#限制每页显示的条数
my_page.page_size=2 page_list=my_page.paginate_queryset(ret,request,self)
ser=BookSer(instance=page_list,many=True)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
cursor_query_param = 'cursor':查询的名字(即浏览器后面跟的名字例如:http://127.0.0.1:8006/page?cursor=cD0y)
page_size = api_settings.PAGE_SIZE:每页显示的条数
ordering = '-created' :按谁排序 #浏览器验证:
#1.http://127.0.0.1:8006/page 首先打开显示2条数据
#2.http://127.0.0.1:8006/page?cursor=cj0xJnA9NQ%3D%3D
''' # return Response(ser.data)
# 对Response做了封装,返回内容里有总条数,上一页,下一页的链接(可避免页面被猜到)
return my_page.get_paginated_response(ser.data) #作用就是打印首页会有上一个和下一页的链接,如下备注
# return Response(ser.data) '''可以手动点击上、下翻页(看不到页码)
"next": "http://127.0.0.1:8006/page?cursor=cD00",
"previous": "http://127.0.0.1:8006/page?cursor=cj0xJnA9Mw%3D%3D",
...
'''

访问效果图:

RESTful-rest_framework版本控制、分页器-第六篇的更多相关文章

  1. 跟我学SpringCloud | 第六篇:Spring Cloud Config Github配置中心

    SpringCloud系列教程 | 第六篇:Spring Cloud Config Github配置中心 Springboot: 2.1.6.RELEASE SpringCloud: Greenwic ...

  2. 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)

    解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...

  3. 解剖SQLSERVER 第六篇 对OrcaMDF的系统测试里避免regressions(译)

    解剖SQLSERVER 第六篇  对OrcaMDF的系统测试里避免regressions (译) http://improve.dk/avoiding-regressions-in-orcamdf-b ...

  4. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  5. 第六篇 :微信公众平台开发实战Java版之如何自定义微信公众号菜单

    我们来了解一下 自定义菜单创建接口: http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_to ...

  6. RabbitMQ学习总结 第六篇:Topic类型的exchange

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  7. 第六篇 Replication:合并复制-发布

    本篇文章是SQL Server Replication系列的第六篇,详细内容请参考原文. 合并复制,类似于事务复制,包括一个发布服务器,一个分发服务器和一个或多个订阅服务器.每一个发布服务器上可以定义 ...

  8. 第六篇 Integration Services:初级工作流管理

    本篇文章是Integration Services系列的第六篇,详细内容请参考原文. 简介在前几篇文章中,我们关注使用增量加载方式加载数据.在本篇文章,我们将关注使用优先约束管理SSIS控制流中的工作 ...

  9. 第六篇 SQL Server安全执行上下文和代码签名

    本篇文章是SQL Server安全系列的第六篇,详细内容请参考原文. SQL Server决定主体是否有必要的执行代码权限的根本途径是其执行上下文规则.这一切都可能复杂一个主体有执行代码的权限,但是却 ...

随机推荐

  1. innerHTML和outerHTML的区别

    一.区别:1)innerHTML: 从对象的起始位置到终止位置的全部内容,不包括Html标签.2)outerHTML: 除了包含innerHTML的全部内容外, 还包含对象标签本身. 二.例子: &l ...

  2. 标准输入输出 stdio 流缓冲 buffering in standard streams

    From : http://www.pixelbeat.org/programming/stdio_buffering/ 译者:李秋豪 我发现找出标准流用的是什么缓冲是一件困难的事. 例如下面这个使用 ...

  3. react 信用卡格式检验

    前言: 技术栈主要基于react + ant-design 描述: 填写信用卡卡号时,会自动四位空格,并格式校验判断卡种  ,这里我们业务只涉及到四种卡. 代码解析 // ant 组件自引,这里我只讲 ...

  4. XAMPP安装过程中,出现的问题

    这次运行一个简单的前端(html+css+js+ajax)+php后端项目,运行XAMPP的时候,出现两个问题: phpmyadmin运行不起来,一直报1544错误 请求本地图片及php文件报403错 ...

  5. c++question 004 c++基本数据类型有哪些?

    (1)signed int类型 整数型 占内存4个字节 一个字节byte 占8个二进制位 一个整型就占32位 (2)short int  短整型 占内存2个字节 一个短整型占16位 (3)long i ...

  6. js时间转换

    1. 将时间戳转换成日期格式 // 简单的一句代码 var date = new Date(时间戳); //获取一个时间对象 /** 1. 下面是获取时间日期的方法,需要什么样的格式自己拼接起来就好了 ...

  7. 十九、MySQL GROUP BY 语句

    MySQL GROUP BY 语句 GROUP BY 语句根据一个或多个列对结果集进行分组. 在分组的列上我们可以使用 COUNT, SUM, AVG,等函数. GROUP BY 语法 SELECT ...

  8. 十四、MySQL UPDATE 查询

    MySQL UPDATE 查询 如果我们需要修改或更新 MySQL 中的数据,我们可以使用 SQL UPDATE 命令来操作.. 语法 以下是 UPDATE 命令修改 MySQL 数据表数据的通用 S ...

  9. k8s的储存方式简述

    pod中的存储卷类型:1.emptyDir:用于临时储存空间,无持久性储存功能,生命周期同pod容器,pod删除后,数据不再存在.2.gitRepo:pod创建时,自动将云端仓库中的文件克隆到pod挂 ...

  10. CentOS 7 bonding模式双网卡绑定

    1.1    查看系统内核是否支持bonding [root@cobbler-node1 ~]# cat /boot/config-3.10.0-693.el7.x86_64 | grep -i bo ...