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实战核心技术第四篇
七 . 吃透索引:...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...
【Python】 -- 趣味代码 - 小恐龙游戏
文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...
零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?
一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具
第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...
Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)
目录 一、👋🏻前言 二、😈sinx波动的基本原理 三、😈波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、🌊波动优化…...
2025年渗透测试面试题总结-腾讯[实习]科恩实验室-安全工程师(题目+回答)
安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 腾讯[实习]科恩实验室-安全工程师 一、网络与协议 1. TCP三次握手 2. SYN扫描原理 3. HTTPS证书机制 二…...
解决:Android studio 编译后报错\app\src\main\cpp\CMakeLists.txt‘ to exist
现象: android studio报错: [CXX1409] D:\GitLab\xxxxx\app.cxx\Debug\3f3w4y1i\arm64-v8a\android_gradle_build.json : expected buildFiles file ‘D:\GitLab\xxxxx\app\src\main\cpp\CMakeLists.txt’ to exist 解决: 不要动CMakeLists.…...
mac:大模型系列测试
0 MAC 前几天经过学生优惠以及国补17K入手了mac studio,然后这两天亲自测试其模型行运用能力如何,是否支持微调、推理速度等能力。下面进入正文。 1 mac 与 unsloth 按照下面的进行安装以及测试,是可以跑通文章里面的代码。训练速度也是很快的。 注意…...
