1.5 django restframework(下)
drf内置了很多便捷的功能,在接下来的课程中会给大家依次讲解下面的内容:
-
快速上手
-
请求的封装
-
版本管理
-
认证
-
权限
-
限流
-
序列化
-
视图
-
条件搜索
-
分页
-
路由
-
解析器
10. 分页
在查看数据列表的API中,如果 数据量 比较大,肯定不能把所有的数据都展示给用户,而需要通过分页展示。
在drf中为我们提供了一些分页先关类:
BasePagination,分页基类 PageNumberPagination(BasePagination) 支持 /accounts/?page=4&page_size=100 格式的分页 LimitOffsetPagination(BasePagination) 支持 ?offset=100&limit=10 格式的分页 CursorPagination(BasePagination) 支持 上一下 & 下一页 格式的分页(不常用)
10.1 APIView视图(手动处理分页)
如果编写视图是直接继承APIView,那么在使用分页时,就必须自己手动 实例化 和 调用相关方法。
1.PageNumberPagination


2.LimitOffsetPagination

3.CursorPagination

10.2 GenericAPIView派生类
如果是使用 ListModelMixin 或 ModelViewSet ,则只需要配置相关类即可,内部会自动执行相关分页的方法。
1.PageNumberPagination
2.LimitOffsetPagination

3.CursorPagination

11. 路由
在之前进行drf开发时,对于路由我们一般进行两种配置:
-
from django.urls import path from app01 import views urlpatterns = [ path('api/users/', views.UserView.as_view()), ]
-
视图如果继承
ViewSetMixin(GenericViewSet、ModelViewSet)一定要写上请求方式和方法名的对应关系from django.urls import path, re_path, include from app01 import views urlpatterns = [ path('api/users/', views.UserView.as_view({"get":"list","post":"create"})), path('api/users/<int:pk>/', views.UserView.as_view({"get":"retrieve","put":"update","patch":"partial_update","delete":"destory"})), ]
对于请求方式和方法名的对应关系这种形式的路由,drf中提供了更简便的方式:(对应关系就不用写了router 内部会自动生成)(如果这样简写 视图类没有继承GenericViewSet、ModelViewSet它 就会报错AttributeError: type object 'TopicView' has no attribute 'get_extra_actions'
-
from rest_framework import routers from app01 import views router = routers.SimpleRouter() router.register(r'api/users', views.UserView) urlpatterns = [ # 其他URL(拓展url) # path('xxxx/', xxxx.as_view()), ] urlpatterns += router.urls
在优化一下 也可以利用include 做路由的分发,给URL加前缀:
from django.urls import path, include from rest_framework import routers from app01 import views router = routers.SimpleRouter() router.register(r'users', views.UserView) #'api/'表示前缀,(router.urls, 'app_name')路由分发 ,省略了上面的 urlpatterns += router.urls和r'api/users'
urlpatterns = [ path('api/', include((router.urls, 'app_name'), namespace='instance_name')),
# 其他URL # path('forgot-password/', ForgotPasswordFormView.as_view()),
]
12. 解析器(Parser)
之前使用 request.data 获取请求体中的数据。
这个 reqeust.data 的数据怎么来的呢?其实在drf内部是由 解析器,根据请求者传入的数据格式 + 请求头来进行处理。
1.JSONParser

2.FormParser(必须用Fromdata数据格式传输)

3.MultiPartParser(适合于即提交数据又提交文件)

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="http://127.0.0.1:8000/test/" method="post" enctype="multipart/form-data"> <input type="text" name="user" /> <input type="file" name="img"> <input type="submit" value="提交"> </form> </body> </html>
4.FileUploadParser(只能上传文件)

解析器可以设置多个,默认解析器:
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.parsers import MultiPartParser, JSONParser, FormParser
class UserView(APIView):
# parser_classes = [MultiPartParser, JSONParser, FormParser,] # 设置多个 默认就是这样的 不用写
def post(self, request):
print(request.content_type)
print(request.data)
return Response("...")
写在最后
至此,drf相关的知识点就全部讲完了。
-
你的感受:单独听的时候都明白,现在感觉自己已经忘记了 并且 还不知道怎么组合起来一起使用。
-
切记:现在千万不要重复回去再看视频,接着往下看学习《drf实战案例》,结合实战功能 & drf各个组件的小项目。
-


浙公网安备 33010602011771号