当前位置: 首页 > news >正文

PageNumberPagination、LimitOffsetPagination、CursorPagination

数据

from django.db import modelsclass User(models.Model):username = models.CharField(max_length=64, verbose_name='用户名')password = models.CharField(max_length=64, verbose_name='密码')# 用户类型user_type = models.IntegerField(choices=((1, '菜鸟用户'), (2, '普通用户'), (3, '超级用户')), verbose_name='用户级别')# 一对一的关系,关联字段写好之后,要考虑谁拿谁的情况多,最好将用的多的放外键
class UserToken(models.Model):token = models.CharField(max_length=64, verbose_name='随机字符串')user = models.OneToOneField(to=User, on_delete=models.CASCADE)# 也等于# user = models.ForeignKey(to=User, unique=True, on_delete=models.CASCADE)class Book(models.Model):title = models.CharField(max_length=32, verbose_name='书名')price = models.IntegerField(verbose_name='书价')publish = models.ForeignKey(to='Publish', on_delete=models.CASCADE)users = models.ManyToManyField(to=User)def publish_detail(self):return {'name': self.publish.name, 'addr': self.publish.addr}def user_list(self):lst = []for user in self.users.all():lst.append({'username': user.username,'password': user.password,'user_type': user.get_user_type_display()})class Publish(models.Model):name = models.CharField(max_length=32, verbose_name='出版社名称')addr = models.CharField(max_length=32, verbose_name='出版社地址')

路由

from django.contrib import admin
from django.urls import path, include
from rest_framework.routers import DefaultRouter, SimpleRouterfrom app01.views import BookViewrouter = SimpleRouter()
router.register('books', BookView, 'books')urlpatterns = [path('admin/', admin.site.urls),path('', include(router.urls))
]

序列化类

from rest_framework import serializers
from rest_framework.exceptions import ValidationError
from .models import User, UserToken, Book, Publishclass UserSerializer(serializers.ModelSerializer):class Meta:model = Userfields = '__all__'class PublishSerializer(serializers.ModelSerializer):class Meta:model = Publishfields = '__all__'class BookSerializer(serializers.ModelSerializer):class Meta:model = Bookfields = ['title', 'price', 'publish', 'users', 'publish_detail', 'user_list']extra_kwargs = {'publish': {'write_only': True},'users': {'write_only': True},}publish_detail = serializers.DictField(read_only=True)user_list = serializers.ListField(read_only=True)def validate_users(self, value):if len(value) > 5:raise ValidationError('一本图书的作者最多5个')return valuedef validate(self, attrs):title = attrs.get('title')publish = attrs.get('publish')# 检查 title 和 publish 是否包含敏感信息sensitive_words = ['SB', 'DJB', 'CNM']for word in sensitive_words:if word in title:raise ValidationError('标题包含敏感信息')if word in publish:raise ValidationError('出版社名称包含敏感信息')return attrs

分页 page.py

from rest_framework.pagination import PageNumberPagination, LimitOffsetPagination, CursorPagination# 继承PageNumberPagination分页
class CommonPageNumberPagination(PageNumberPagination):# 过滤形式# http://api.example.org/accounts/?page=4# http://api.example.org/accounts/?page=4&page_size=100# 需要重写几个类属性page_size = 3  # 每页显示2条page_query_param = 'page'  # 指定第几页的 key 值page_size_query_param = 'size'  # 指定每页显示多少条max_page_size = 5  # 每页最多显示5条# 继承LimitOffsetPagination分页
class CommonLimitOffsetPagination(LimitOffsetPagination):# 过滤形式# http://api.example.org/accounts/?limit=3  从开始取3条# http://api.example.org/accounts/?offset=4&limit=5  从第4条开始取5条default_limit = 2  # 默认每页显示3条limit_query_param = 'limit'  # 每页显示多少条的查询条件offset_query_param = 'offset'max_limit = 5# 继承CursorPagination分页
class CommonCursorPagination(CursorPagination):# 只能上一条和下一条,不能指定跳转到中间的某页----》效率高,大数据cursor_query_param = 'cursor'  # 查询条件,用不到,需要有page_size = 2  # 每页显示2条ordering = 'id'  # 按id排序

视图函数

PageNumberPagination

from rest_framework.generics import GenericAPIView
from rest_framework.response import Responsefrom .models import Book
from .serializer import BookSerializer
from rest_framework.viewsets import ViewSetMixinfrom .page import CommonPageNumberPaginationclass BookView(ViewSetMixin, GenericAPIView):queryset = Book.objects.all()serializer_class = BookSerializerpagination_class = CommonPageNumberPaginationdef list(self, request, *args, **kwargs):# 查询所有数据queryset = self.filter_queryset(self.get_queryset())# 分页处理page_list = self.paginate_queryset(queryset)if page_list:ser = self.get_serializer(page_list, many=True)return self.get_paginated_response(data=ser.data)ser = self.get_serializer(queryset, many=True)return Response(ser.data)

LimitOffsetPagination

from .page import CommonLimitOffsetPaginationclass BookView(ViewSetMixin, GenericAPIView):queryset = Book.objects.all()serializer_class = BookSerializerpagination_class = CommonLimitOffsetPaginationdef list(self, request, *args, **kwargs):# 获取查询集queryset = self.filter_queryset(self.get_queryset())# 分页处理page_list = self.paginate_queryset(queryset)if page_list:serializer = self.get_serializer(page_list, many=True)return self.get_paginated_response(serializer.data)serializer = self.get_serializer(queryset, many=True)return Response(serializer.data)

CursorPagination

from .page import CommonCursorPaginationclass BookView(ViewSetMixin, GenericAPIView):queryset = Book.objects.all()serializer_class = BookSerializerpagination_class = CommonCursorPaginationdef list(self, request, *args, **kwargs):# 获取查询集queryset = self.filter_queryset(self.get_queryset())# 分页处理page_list = self.paginate_queryset(queryset)if page_list is not None:serializer = self.get_serializer(page_list, many=True)return self.get_paginated_response(serializer.data)serializer = self.get_serializer(queryset, many=True)return Response(serializer.data)

报错

1.先写个函数
from rest_framework.views import exception_handler
from rest_framework.response import Responsedef common_exception(exc, context):res = exception_handler(exc, context)if not res:return Response({'code': 999, 'msg': f'非drf错误,错误信息是:{str(exc)}'})return Response({'code': 666, 'msg': f'这是drf错误,错误信息是:{res.data.get("detail")}'})2.在配置文件中配置:REST_FRAMEWORK = {# 以后只要除了异常,都会走这个函数'EXCEPTION_HANDLER': 'app01.exceptions.common_exception',
}
http://www.lryc.cn/news/157890.html

相关文章:

  • 怎么把视频转换成mp4格式
  • 正则判断字符是否包含手机号
  • OSCP系列靶场-Esay-Sumo
  • 本地电脑搭建web服务器、个人博客网站并发布公网访问 【无公网IP】(1)
  • Python基础List列表定义与函数
  • typeScript--[数据定义]
  • 【常见相机模型】
  • 大数据-玩转数据-Flink状态编程(上)
  • 主动获取用户的ColaKey接口
  • C#写一个UDP程序判断延迟并运行在Centos上
  • Kafka核心原理第二弹——更新中
  • 巨人互动|游戏出海H5游戏出海规模如何?
  • 【爬虫】实验项目三:验证码处理与识别
  • 广东成人高考报名将于9月14日开始!
  • pytorch中文文档学习笔记
  • element-ui全局导入与按需引入
  • go 地址 生成唯一索引v2 --chatGPT
  • JSON XML
  • 2023年MySQL实战核心技术第四篇
  • cmake编译(qtcreator)mingw下使用的osg3.6.5
  • Python钢筋混凝土结构计算.pdf-混凝土强度设计值
  • elasticsearch的索引库操作
  • 把握市场潮流,溯源一流品质:在抖in新风潮 国货品牌驶过万重山
  • 【网络教程】Python如何优雅的分割URL
  • 1998-2014年工业企业数据库和绿色专利匹配
  • Python基于Mirai开发的QQ机器人保姆式教程(亲测可用)
  • 算法笔记:堆
  • vue3 判断包含某个字符
  • MySQL的故事——查询性能优化
  • 在外SSH远程连接macOS服务器【cpolar内网穿透】