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',
}相关文章:
PageNumberPagination、LimitOffsetPagination、CursorPagination
数据 from django.db import modelsclass User(models.Model):username models.CharField(max_length64, verbose_name用户名)password models.CharField(max_length64, verbose_name密码)# 用户类型user_type models.IntegerField(choices((1, 菜鸟用户), (2, 普通用户), …...
怎么把视频转换成mp4格式
怎么把视频转换成mp4格式?如今,随着科技的不断发展,我们在工作中接触到的多媒体视频格式也越来越多。其中,MP4作为一种广泛兼容的视频格式,在许多软件中都能轻松播放,并且成为了剪辑与裁剪视频时大家常用的…...
正则判断字符是否包含手机号
字符前后不能是数字,满足手机号标准 String msg "19009098989";String mobliePattern "((?<!\\d))(mobile|手机号|)(|\\[|\\\":\\\"|:|:||:|)(1)([3-9]{1}\\d{1})(\\d{4})(\\d{4})(\\]|\\\"||)((?!\\d))";String mobileR…...
OSCP系列靶场-Esay-Sumo
OSCP系列靶场-Esay-Sumo 总结 getwebshell : nikto扫描 → 发现shellshock漏洞 → 漏洞利用 → getwebshell 提 权 思 路 : 内网信息收集 → 内核版本较老 →脏牛提权 准备工作 启动VPN 获取攻击机IP → 192.168.45.194 启动靶机 获取目标机器IP → 192.168.190.87 信息收…...
本地电脑搭建web服务器、个人博客网站并发布公网访问 【无公网IP】(1)
文章目录 前言1. 安装套件软件2. 创建网页运行环境 指定网页输出的端口号3. 让WordPress在所需环境中安装并运行 生成网页4. “装修”个人网站5. 将位于本地电脑上的网页发布到公共互联网上 前言 在现代社会,网络已经成为我们生活离不开的必需品,而纷繁…...
Python基础List列表定义与函数
如何定义一个非空的列表? name_list ["liming","xiaohong",15,{"hobby":"basketball"}] 列表的特点: 1.列表是有序的 2.可以存放多个元素 3.每个元素可以是任何数据类型 定义一个空列表 name_list [] 访…...
typeScript--[数据定义]
一.安装ts 1.命令行运行如下命令,全局安装 TypeScript: npm install -g typescript2.安装完成后,在控制台运行如下命令,检查安装是否成功 tsc -V 二.创建ts文件 1.创建一个day01.ts文件,随便在里面码一点代码&…...
【常见相机模型】
常见相机模型 enum class Type {kPinhole 0,kUnifiedProjection 1,kOmni 2, //optimize_on_spherekEqFisheye 3};其余类型optimize_on_plane这4种类型的相机模型具有以下差异: kPinhole (针孔相机模型):这是最基本和常见的相机模型。它假设光线通过…...
大数据-玩转数据-Flink状态编程(上)
一、Flink状态编程 有状态的计算是流处理框架要实现的重要功能,因为稍复杂的流处理场景都需要记录状态,然后在新流入数据的基础上不断更新状态。 SparkStreaming在状态管理这块做的不好, 很多时候需要借助于外部存储(例如Redis)来手动管理状态, 增加了编…...
主动获取用户的ColaKey接口
主动获取用户的ColaKey接口 一、主动获取用户的ColaKey接口二、使用步骤1、接口***重要提示:建议使用https协议,当https协议无法使用时再尝试使用http协议***2、请求参数 三、 请求案例和demo1、请求参数例子(POST请求,参数json格式)2、响应返…...
C#写一个UDP程序判断延迟并运行在Centos上
服务端 using System.Net.Sockets; using System.Net;int serverPort 50001; Socket server; EndPoint client new IPEndPoint(IPAddress.Any, 0);//用来保存发送方的ip和端口号CreateSocket();void CreateSocket() {server new Socket(AddressFamily.InterNetwork, SocketT…...
Kafka核心原理第二弹——更新中
架构原理 一、高吞吐机制:Batch打包、缓冲区、acks 1. Kafka Producer怎么把消息发送给Broker集群的? 需要指定把消息发送到哪个topic去 首先需要选择一个topic的分区,默认是轮询来负载均衡,但是如果指定了一个分区key&#x…...
巨人互动|游戏出海H5游戏出海规模如何?
H5游戏出海是指将H5游戏推广和运营扩展到国外市场的行为,它的规模受到多个因素的影响。本文小编讲一些关于H5游戏出海规模的详细介绍。 1、市场规模 H5游戏出海的规模首先取决于目标市场的规模。不同国家和地区的游戏市场规模差异很大,有些市场庞大而成…...
【爬虫】实验项目三:验证码处理与识别
目录 一、实验目的 二、实验预习提示 三、实验内容 实验要求 基本要求: 改进要求A: 改进要求B: 四、实验过程 基本要求 五、源码如下 六、资料 一、实验目的 部分网站可能会使用验证机制来阻止用户无效登录或者是验证用户不是用程…...
广东成人高考报名将于9月14日开始!
截图来自广东省教育考试院官网* 今年的广东成人高考正式报名时间终于确定了! 报名时间:2023年 9 月14—20日 准考证打印时间:考前一周左右 考试时间:2023年10月21—22日 录取时间:2023年12 月中上旬 报名条件: …...
pytorch中文文档学习笔记
先贴上链接 torch - PyTorch中文文档 首先我们需要安装拥有pytorch的环境 conda指令 虚拟环境的一些指令 查看所有虚拟环境 conda info -e 创建新的虚拟环境 conda create -n env_name python3.6 删除已有环境 conda env remove -n env_name 激活某个虚拟环境 activate env…...
element-ui全局导入与按需引入
全局引入 npm i element-ui -S 安装好depencencies里面可以看到安装的element-ui版本 然后 在 main.js 中写入以下内容: import Vue from vue; import ElementUI from element-ui; import element-ui/lib/theme-chalk/index.css; import App from ./App.vue;Vue.…...
go 地址 生成唯一索引v2 --chatGPT
问:golang 函数 getIndex(n,addr,Hlen,Tlen) 返回index。参数n为index的上限,addr为包含大小写字母数字的字符串,Hlen为截取addr头部的长度,Tlen为截取addr尾部的长度 gpt: 你可以编写一个函数来计算根据给定的参数 n、addr、Hlen 和 Tlen …...
JSON XML
JSON(JavaScript Object Notation)和XML(eXtensible Markup Language)是两种常用的数据交换格式,用于在不同系统之间传输和存储数据。 JSON是一种轻量级的数据交换格式,它使用易于理解的键值对的形式表示数…...
2023年MySQL实战核心技术第四篇
七 . 吃透索引:...
TLM通信:从基础操作到UVM高级连接模式
1. TLM通信基础:从信号级到事务级的跨越 第一次接触TLM这个概念时,我正被一堆信号线搞得焦头烂额。当时在做一个以太网MAC验证项目,每次调试都要跟踪几十根信号线的时序,简直像在解一团乱麻。直到同事提醒我:"为什…...
Arm Cortex-A78处理器仿真技术与Iris架构实践
1. Arm Cortex-A78AE/A78C处理器仿真技术解析在半导体设计领域,处理器仿真技术已经成为芯片开发流程中不可或缺的关键环节。作为Armv8.2-A架构的代表性产品,Cortex-A78AE和A78C处理器采用了创新的Iris组件体系进行建模,这种基于指令集架构(IS…...
Adafruit Metro M4 AirLift开发板:硬件解析与物联网开发实战
1. 项目概述与硬件解析如果你正在寻找一款既能提供强大本地计算能力,又能轻松接入无线网络的微控制器开发板,那么Adafruit Metro M4 Express AirLift绝对是一个值得深入研究的选项。它不是简单的单片机加WiFi模块的堆砌,而是一个经过精心整合…...
4.【Python】Python3 注释
第一步:分析与整理 注释1. 注释的作用 不影响程序执行,只提高可读性。帮助理解代码逻辑,方便团队协作。2. 单行注释 以 # 开头,直到行末的所有内容均为注释。 # 这是一个注释 print("Hello, World!") # 这也是注释3. 多…...
重磅!国家首部NAD⁺抗衰共识发布,这11条建议必读!
2026年4月,国内首个《NAD⁺在衰老相关疾病中的作用及临床应用中国专家共识(2026版)》正式发布!这份由中华医学会老年医学分会牵头、汇聚全国衰老医学、代谢病、心血管病及神经病学等领域权威专家共同制定的国家级共识,…...
植物大战僵尸杂交版手机版最新版v3.16.1安卓2026最新下载分享
作为长期沉迷植物大战僵尸改版的老玩家,我近期完整体验了杂交版全新V3.16版本,从植物、关卡到平台适配,逐一实测验证。 整体来说,这是一次诚意满满的更新——既有新鲜玩法创新,又兼顾不同玩家需求。 下载链接&#x…...
政府新媒体宣发审核和监测对内容合规有哪些意义
在政务新媒体全谱系发展的今天,信息发布面临着意识形态安全、法律合规、公民隐私保护等多重考验。建立完善的宣发审核与监测机制,对保障内容合规具有决定性的意义,它是数字政府建设中不可或缺的“安全阀”与“过滤器”。以下是宣发审核和监测…...
开源音频标注工具audamo:从部署到实战的全流程指南
1. 项目概述:一个为音频数据标注而生的开源工具如果你正在处理语音识别、音频事件检测或者任何需要大量标注音频数据的项目,那么“标注”这个环节大概率是你工作流中最耗时、也最令人头疼的部分。手动用Audacity一帧一帧地听、标记,效率低下不…...
免费国产模型清单
下面给你整理了能在国内稳定使用、可通过中转接入 Claude Code 的国产免费模型,同时附接入方式和适配说明,帮你快速替换驱动👇 一、免费国产模型清单(公开 API / 兼容格式) 这些模型支持 OpenAI/Anthropic 兼容接口&a…...
大模型低显存优化实战:量化、KV Cache与动态加载技术解析
1. 项目概述:低显存环境下的OpenClaw模型优化实战最近在GitHub上看到一个挺有意思的项目,标题是“openclaw-lowmem-optimization”。光看名字,就能猜到这大概是在做一件什么事:针对OpenClaw这个模型,进行低显存&#x…...
