RESTful-rest_framework版本控制、分页器-第六篇
版本控制:
源码位置分析第一步:
源码位置分析第二步:在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版本控制、分页器-第六篇的更多相关文章
- 跟我学SpringCloud | 第六篇:Spring Cloud Config Github配置中心
SpringCloud系列教程 | 第六篇:Spring Cloud Config Github配置中心 Springboot: 2.1.6.RELEASE SpringCloud: Greenwic ...
- 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)
解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...
- 解剖SQLSERVER 第六篇 对OrcaMDF的系统测试里避免regressions(译)
解剖SQLSERVER 第六篇 对OrcaMDF的系统测试里避免regressions (译) http://improve.dk/avoiding-regressions-in-orcamdf-b ...
- Python之路【第十六篇】:Django【基础篇】
Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...
- 第六篇 :微信公众平台开发实战Java版之如何自定义微信公众号菜单
我们来了解一下 自定义菜单创建接口: http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_to ...
- RabbitMQ学习总结 第六篇:Topic类型的exchange
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- 第六篇 Replication:合并复制-发布
本篇文章是SQL Server Replication系列的第六篇,详细内容请参考原文. 合并复制,类似于事务复制,包括一个发布服务器,一个分发服务器和一个或多个订阅服务器.每一个发布服务器上可以定义 ...
- 第六篇 Integration Services:初级工作流管理
本篇文章是Integration Services系列的第六篇,详细内容请参考原文. 简介在前几篇文章中,我们关注使用增量加载方式加载数据.在本篇文章,我们将关注使用优先约束管理SSIS控制流中的工作 ...
- 第六篇 SQL Server安全执行上下文和代码签名
本篇文章是SQL Server安全系列的第六篇,详细内容请参考原文. SQL Server决定主体是否有必要的执行代码权限的根本途径是其执行上下文规则.这一切都可能复杂一个主体有执行代码的权限,但是却 ...
随机推荐
- hdu-3572 Task Schedule---最大流判断满流+dinic算法
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3572 题目大意: 给N个任务,M台机器.每个任务有最早才能开始做的时间S,deadline E,和持 ...
- 【BZOJ3925】[ZJOI2015] 地震后的幻想乡(状压期望DP)
点此看题面 大致题意: 有\(n\)个点和\(m\)条边,每条边的权值是一个\(0\sim1\)的随机实数,要你用\(n-1\)条边将图联通,问这\(n-1\)条边中边权最大值的期望最小值. 提示 这 ...
- 跑rbgirshick的fast-rcnn代码
需要安装Caffe.pycaffe cython.python-opencv.easydict matlab(主要用于对PASCALvoc数据集的评估) 为什么要bulid cython.caffe. ...
- 感谢我的python老师
Python自动化开发(金角大王版) http://www.cnblogs.com/alex3714/articles/5885096.html
- OO第四单元总结
单元架构设计 本单元OO作业主要涉及两个过程,即先根据输入的elements数组建立UML存储模型,而后基于这个模型实现一系列查询判断功能.汲取上单元的经验,建模过程中模型数据容器的选择依据要求实现的 ...
- vue-awesome-swiper实现轮播图
1.首先通过npm安装vue-awesome-swiper,我在项目中用的是2.6.7版本 npm install vue-awesome-swiper@2.6.7 –save 2. 在main.js ...
- MultipartFile 动态决定是否上传文件,解决不上传文件报错
controller 接收参数 用 HttpServletRequest 代替 @RequestParam() 接收参数 picFile 前台 传文件的参数名字 , 这样 前段 传 nul ...
- PS1
linux系统终端命令提示符设置(PS1)记录 - 散尽浮华 - 博客园 https://www.cnblogs.com/kevingrace/p/5985970.html PS(Prompt Sig ...
- Python 正则表达式 匹配任意字符
.(句点)匹配除了换行之外的所有一个字符, .*(点-星)匹配除了换行外的所有字符 >>> >>> r=re.compile(r'.*')>>> ...
- Linux usb gadget框架概述
很幸运,在公司开发了gadget相关驱动,总结下来,大大小小开发了四个与gadget相关的驱动,字符驱动.g_multi.g_ether.g_zero,在这里把自己对gadget的开发中自己的感悟记录 ...