Django Rest Framework url注册器组件 | 响应器组件 | 分页器组件

文章参考博主:https://www.cnblogs.com/li-li/p/10103918.html 

1.url注册器组件 :

通过DRF的视图组件,数据接口逻辑被我们优化到最后剩下一个类,接下来,我们使用DRF的url控制器来帮助我们自动生成url

‘‘‘3.使用url注册器组件的url‘‘‘
#导入模块
from rest_framework import routers
router = routers.DefaultRouter()

# 3.将需要自动生成url的接口注册到router中
router.register(‘book‘, views.BookView)
# router.register(‘user‘,views.UserView)
# 4.生成url
urlpatterns = [
    re_path(‘^‘, include(router.urls)),
    re_path(r‘user/$‘,views.UserView.as_view()),
]

2.响应器组件:

  之前我们使用DRF的Response类来将数据响应给客户端,不管是POSTMAN还是浏览器,都能浏览到经过格式化后的漂亮的数据,DRF是怎么做的呢?其实就是通过响应器组件。

  如果我们不需要使用DRF提供给浏览器的格式化后的数据,只需要禁止该响应方式即可:

from rest_framework.renderers import JSONRenderer

class BookView(ModelViewSet):

    renderer_classes = [JSONRenderer]

    queryset = Book.objects.all()
    serializer_class = BookSerializer

  这样,浏览器再次访问,接收到的就是普通的json格式数据,而不是经过DRF格式化后的数据,renderer_classes的查找逻辑与之前的解析器等组件是完全一样的。

4.分页器组件:

  为了服务器性能考虑,也为了用户体验,我们不应该一次将所有的数据从数据库中查询出来,返回给客户端浏览器,如果数据量非常大,这对于服务器来讲,可以说是性能灾难,而对于用户来讲,加载速度将会非常慢。

  所以,我们需要控制每次返回给客户端多少数据,这就需要用到分页器。

1、接下来,介绍一下DRF的局部实现分页器组件

# 1.导入模块
from rest_framework.pagination import PageNumberPagination

# 自定义分页器类,继承PageNumberPagination
class MyPagination(PageNumberPagination):
    page_size = 3
    page_query_param = ‘p‘
    page_size_query_param = ‘size‘
    max_page_size = 5

class BookView(APIView):

    def get(self, request):
        # 2.获取数据
        queryset = Book.objects.all()
        # 3.创建分页器对象
        paginater = MyPagination()
        # 4.开始分页
        paged_books = paginater.paginate_queryset(queryset, request)
        # 5.将分页后的数据进行序列化
        serializer_books = BookSerializer(paged_books, many=True)
        # 6.返回数据
        return Response(serializer_books.data)

2、参数介绍

page_size:用来控制每页显示多少条数据(全局参数名为PAGE_SIZE);
page_query_param:用来提供直接访问某页的数据;
page_size_query_param:临时调整当前显示多少条数据;
max_page_size:控制page_size_query_param参数能调整的最大条数;

3、在ModelViewSet中使用分页器

from rest_framework.viewsets import ModelViewSet
from rest_framework.pagination import PageNumberPagination

# 自定义分页器类
class MyPagination(PageNumberPagination):
    page_size = 3
    page_query_param = ‘p‘
    page_size_query_param = ‘size‘
    max_page_size = 5

class BookView(ModelViewSet):

    pagination_class = MyPagination      # 指定分页器类

    queryset = Book.objects.all()
    serializer_class = BookSerializer

4、分页器全局配置

REST_FRAMEWORK = {
    ‘DEFAULT_PAGINATION_CLASS‘: ‘rest_framework.pagination.PageNumberPagination‘,
    ‘PAGE_SIZE‘: 10  # 每页数目
}

原文地址:https://www.cnblogs.com/cou1d/p/12344626.html

时间: 2024-08-28 16:33:17

Django Rest Framework url注册器组件 | 响应器组件 | 分页器组件的相关文章

DjangoRestFramework学习三之认证组件、权限组件、频率组件、url注册器、响应器、分页组件

本节目录 一 认证组件 二 权限组件 三 频率组件 四 URL注册器 五 响应器 六 分页组件 七 xxx 八 xxx 一 认证组件 1. 局部认证组件 我们知道,我们不管路由怎么写的,对应的视图类怎么写的,都会走到dispatch方法,进行分发, 在咱们看的APIView类中的dispatch方法的源码中,有个self.initial(request, *args, **kwargs),那么认证.权限.频率这三个默认组件都在这个方法里面了,如果我们自己没有做这三个组件的配置,那么会使用源码中默

rest_framework中的url注册器,分页器,响应器

url注册器: 对于authors表,有两个url显得麻烦: rest_framework将我们的url进行了处理: 这样写了之后,就可以像原来一样访问author表了. 故意写错路径,看看它为我们做了哪些配置: 在有关author的路径中,只有1和3条url是和我们原来路径一样的,多了两条额外的url,对于这两条url,多了format的命名分组,我们可以这样访问: 也就是说,我们可以按照不同的编码格式进行访问. 分页器: 当我们的数据量巨大时,前端只想要某些数据,就可以利用分页来选取数据.

DRF Django REST framework 之 频率,响应器与分页器组件(六)

频率组件 频率组件类似于权限组件,它判断是否给予请求通过.频率指示临时状态,并用于控制客户端可以向API发出的请求的速率. 与权限一样,可以使用多个调节器.API可能会对未经身份验证的请求进行限制,而对于经过身份验证的请求则进行限制较少. 例如,可以将用户限制为每分钟最多60个请求,每天最多1000个请求. 自定义频率组件 使用方式与权限,认证组件几乎相同 该方式没有DRF提供的方式简洁 import time import math from rest_framework import exc

Django Rest Framework之解析器

基本代码结构 urls.py: from django.conf.urls import url, include from web.views.s5_parser import TestView urlpatterns = [ url(r'test/', TestView.as_view(), name='test'), ] views.py: from rest_framework.views import APIView from rest_framework.response impor

django rest framework 之 解析器

一.前言 在前端向后台发送form表单或者ajax数据的时候,django的content_type会拿到请求头中的Content-Type属性然后根据值进行解析. 将request.data中的值放到request.POST中需要满足两个条件 请求头要求: Content-Type: application/x-www-form-urlencoded PS: 如果请求头中的 Content-Type: application/x-www-form-urlencoded,request.POST

Django REST framework之解析器实例以及源码流程分析

解析器 我们都知道源生Django默认只能解析content-type:application/x-www-form-urlencoded头格式的,若果是json格式,form-data格式都要自己处理. 但是在restframework已经为我们做好了,只要配置上,就能帮我们解析请求的数据 举例说明: 表设计: 1 from django.db import models 2 3 4 class UserGroup(models.Model): 5 title = models.CharFie

Django rest framework(5) ---解析器

(1)api/urls.py # api/urls.py from django.urls import path,re_path from .views import UserView,PaserView urlpatterns = [ re_path('(?P<version>[v1|v2]+)/users/', UserView.as_view(),name = 'api_user'), path('paser/', PaserView.as_view(),), #解析 ] (2)vie

Django Restful Framework【第三篇】认证、权限、限制访问频率

一.认证 认证请求头 views.py #!/usr/bin/env python # -*- coding:utf-8 -*- from rest_framework.views import APIView from rest_framework.response import Response from rest_framework.authentication import BaseAuthentication from rest_framework.permissions import

轻轻松松学会 DRF Django REST framework

DRF Django REST framework 之 APIView(一) DRF Django REST framework 之 解析器(二) DRF Django REST framework 之 序列化(三) DRF Django REST framework 之 视图组件(四) 持续更新中.... 原文地址:https://www.cnblogs.com/pungchur/p/12028316.html