DRF - 加密分页
可以在 settings.py 中设置每页显示的数据数量
1 2 3 | REST_FRAMEWORK = { "PAGE_SIZE" : 2 , # 每页显示 2 条内容 } |
views.py:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | from rest_framework import serializers from rest_framework.pagination import CursorPagination from drf import models class MyPagination(CursorPagination): cursor_query_param = 'cursor' # 参数 page_size = 2 # 每页的数量 ordering = 'id' # 以 id 为排序数据 page_size_query_param = None # 每页数量的参数 max_page_size = None # 每页最大的数量 class PagerSerializer(serializers.ModelSerializer): class Meta: model = models.Role fields = "__all__" class PagerView(APIView): def get( self , request, * args, * * kwargs): # 获取 Role 表中的所有数据 role_obj = models.Role.objects. all () # 创建分页对象 page_obj = MyPagination() # 将从数据库中获取的数据进行分页 role_page = page_obj.paginate_queryset( queryset = role_obj, request = request, view = self , ) # 对数据序列化 ser = PagerSerializer(instance = role_page, many = True ) # 使用分页的 response 进行返回 return page_obj.get_paginated_response(ser.data) |
因为每一页的 URL 地址都是加密的,所以这里需要用分页的 response 进行返回,方便查看前一页和后一页的 URL 链接
下一条数据的地址
前后页面的地址都被加密了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架