0013 基于DRF框架开发(01 基类视图 APIView)
之前学习了模型序列化和普通序列化,我们用最简单的视图和url实现了对序列化的操作。
而实际上,象之前那种由DRF自动生成所有的视图和url的情况,在应用是使用很少。而需要用户根据实际业务需求,自定义视图和url。
DRF提供了丰富的视图类,可以满足程序员的各种需求,基本上一个需求可以用多种视图来满足。
1 导入包
找到Applications/Exampls/views下的Schools.py文件,先导入以下包:
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import status
from GeneralTools.CustomSchema import CustomSchema
from coreapi import Field
from coreschema import String
APIView根据浏览器url请求中是否带有ID参数分为两类。
2 url不带参请求
url不带参请求:浏览器请求时url中不带参数,主要用于查询和新增,与之对应的是get和post方法
不带参请求的类名格式为:模型名+List
在Schools.py中增加一个类,SchoolListView,代码如下:
class SchoolListView(APIView):
schema = CustomSchema(
manual_fields={
'post': [
Field(name='name', required=True, location='form', schema=String(description='学校名称')),
Field(name='email', required=False, location='form', schema=String(description='学校邮箱')),
Field(name='phone', required=True, location='form', schema=String(description='学校座机')),
Field(name='employment_rate', required=True, location='form', schema=String(description='就业率')),
Field(name='teacher_quantity', required=True, location='form', schema=String(description='教师人数')),
Field(name='student_quantity', required=True, location='form', schema=String(description='学生人数')),
Field(name='sms_code', required=True, location='form', schema=String(description='验证码')),
]
}
) @classmethod
def get(cls, request):
"""
【功能描述】用于查询所有学校信息</br>
【返回参数】</br>
1 name:学校名称</br>
2 email:学校电子邮箱</br>
3 phone:学校座机</br>
4 employment_rate:就业率</br>
5 teacher_quantity:教师人数</br>
6 student_quantity:学生人数</br>
"""
schools = Schools.objects.all()
serializer = SchoolsSerializer(schools, many=True)
return Response(serializer.data) @classmethod
def post(cls, request):
"""
【功能描述】用于新增学校信息</br>
【返回参数】</br>
1 成功返回201</br>
2 失败返回出错信息</br>
"""
serializer = SchoolsSerializer(data=request.data)
serializer.is_valid(raise_exception=True)
serializer.save()
return Response(serializer.data, status=status.HTTP_201_CREATED)
为视图SchoolListViews增加一个url:path('SchoolList/', SchoolListView.as_view()),并在测试文档中测试,如图:

3 url带参数请求
带参数请求,主要是需要url中带上记录ID进行请求,主要用于查询指定记录(对应get方法),更改指定记录(对应put方法),删除指定记录(对应delete方法)
带参数请求的类名为:模型名+DetailView
在Schools.py中增加一个类,SchoolDetailView,代码如下:
class SchoolDetailView(APIView):
schema = CustomSchema(
manual_fields={
'put': [
Field(name='name', required=True, location='form', schema=String(description='学校名称')),
Field(name='email', required=False, location='form', schema=String(description='学校邮箱')),
Field(name='phone', required=True, location='form', schema=String(description='学校座机')),
Field(name='employment_rate', required=True, location='form', schema=String(description='就业率')),
Field(name='teacher_quantity', required=True, location='form', schema=String(description='教师人数')),
Field(name='student_quantity', required=True, location='form', schema=String(description='学生人数')),
Field(name='sms_code', required=True, location='form', schema=String(description='验证码')),
]
}
) @classmethod
def get(cls, request, pk):
"""
【功能描述】根据ID查询指定记录</br>
【返回参数】</br>
1 name:学校名称</br>
2 email:学校电子邮箱</br>
3 phone:学校座机</br>
4 employment_rate:就业率</br>
5 teacher_quantity:教师人数</br>
6 student_quantity:学生人数</br>
"""
try:
school = Schools.objects.get(pk=pk)
except Schools.DoesNotExist:
raise status.HTTP_404_NOT_FOUND
serializer = SchoolsSerializer(school)
return Response(serializer.data) @classmethod
def put(cls, request, pk):
"""
【功能描述】根据ID修改指定记录
【返回参数】</br>
1 name:学校名称</br>
2 email:学校电子邮箱</br>
3 phone:学校座机</br>
4 employment_rate:就业率</br>
5 teacher_quantity:教师人数</br>
6 student_quantity:学生人数</br>
"""
try:
school = Schools.objects.get(pk=pk)
except Schools.DoesNotExist:
raise status.HTTP_404_NOT_FOUND
serializer = SchoolsSerializer(school, data=request.data)
serializer.is_valid(raise_exception=True)
serializer.save()
return Response(serializer.data) @classmethod
def delete(cls, request, pk):
"""
【功能描述】根据ID删除指定学校
【返回参数】</br>
1 成功返回204</br>
2 失败返回出错信息</br>
"""
try:
school = Schools.objects.get(pk=pk)
except Schools.DoesNotExist:
raise status.HTTP_404_NOT_FOUND
school.delete()
return Response(status=status.HTTP_204_NO_CONTENT)
为视图SchoolDetailView增加一个url:path('SchoolDetail/<int:pk>', SchoolDetailView.as_view()),并在测试文档中测试,如图:

0013 基于DRF框架开发(01 基类视图 APIView)的更多相关文章
- 0014 基于DRF框架开发(02 基类视图 GenericAPIView)
前端于对数据操作的请求基本上就分为四类:增删改查,即增加.删除.修改.查询. 而DRF把前端请求分为两个大类:带ID参数请求和不带ID参数请求. 不带ID参数请求包括:增加.分布多条查询 带ID参数请 ...
- 0008 基于DRF框架开发(01 DRF开发的基本流程)
1 创建模型 由于之前在<004 工程配置>中,已在Applications/Organizations/models中创建了一个UserInfo模型.此处引用这个模型. from dja ...
- 0009 基于DRF框架开发(02 创建模型)
上一节介绍了DRF开发的基本流程,共五个步骤: 1 创建模型 2 创建序列化器 3 编写视图 4 配置URL 5 运行测试 本节主要讲解创建模型. 构建学校,教师,学生三个模型,这三个模型之间的关系是 ...
- 0010 基于DRF框架开发(03 模型序列化器)
序列化器:是指从数据库提取数据,转化前端所需要的数据格式并返回到前端. 反序列化器:是指把前端传回的数据,转换成数据库需要的格式,存入数据库. DRF提供了两种序列化器: 模型序列化器:是指和模型关联 ...
- 0012 基于DRF框架开发(04 序列化器的字段与选项)
1 常用字段类型 字段 构造方式 BooleanField BooleanField() NullBooleanField NullBooleanField() CharField CharField ...
- 0011 基于DRF框架开发(04 普通序列化器)
普通序列化器和模型无关,只是对针对提交字段的定义. 本文定义三个序列化器: 教师序列化器,学生序列化器,教师学生序列化器.这三个序列化器都使用普通序列化器. 1 教师序列化器 在Application ...
- 基于SSH框架开发的《高校大学生选课系统》的质量属性的实现
基于SSH框架开发的<高校大学生选课系统>的质量属性的实现 对于可用性采取的是错误预防战术,即阻止错误演变为故障:在本系统主要体现在以下两个方面:(1)对于学生登录模块,由于初次登陆,学生 ...
- MapReduce教程(一)基于MapReduce框架开发<转>
1 MapReduce编程 1.1 MapReduce简介 MapReduce是一种编程模型,用于大规模数据集(大于1TB)的并行运算,用于解决海量数据的计算问题. MapReduce分成了两个部分: ...
- drf框架serializers中ModelSerializer类简化序列化和反序列化操作
0905自我总结 drf框架serializers中ModelSerializer类 基于seriallizer类进行简化 https://www.cnblogs.com/pythonywy/p/11 ...
随机推荐
- mongo 集群(副本)搭建过程记录
最近搭建mongo集群,回忆总结,作以记录.整个过程主要参考以下两篇文章,但是过程并不顺利,有些问题需要记录.https://www.cnblogs.com/dba-devops/p/7130710. ...
- 《C# 爬虫 破境之道》:第二境 爬虫应用 — 第六节:反爬策略研究
之前的章节也略有提及反爬策略,本节,我们就来系统的对反爬.反反爬的种种,做一个了结. 从防盗链说起: 自从论坛兴起的时候,网上就有很多人会在论坛里发布一些很棒的文章,与当下流行的“点赞”“分享”一样, ...
- 使用github--stanfordnlp--glove训练自己的数据词向量
1.准备语料 准备好自己的语料,保存为txt,每行一个句子或一段话,注意要分好词.将分好词的语料保存为×××.txt 2.准备源码 下载地址:https://github.com/stanfordnl ...
- 数据算法 --hadoop/spark数据处理技巧 --(1.二次排序问题 2. TopN问题)
一.二次排序问题. MR/hadoop两种方案: 1.让reducer读取和缓存给个定键的所有值(例如,缓存到一个数组数据结构中,)然后对这些值完成一个reducer中排序.这种方法不具有可伸缩性,因 ...
- onboard procossor and cross-compile
星载处理器 ERC32-TSC695F The European Space Agency’s ERC32 is a microprocessor implementing a SPARC V7 pr ...
- Visual C# 2015调用SnmpSharpNet库实现简单的SNMP元素查询
一开始调研发现有几个SNMP的库, 一个是net-SNMP,这个好像是linux用的多 一个是微软自己的WinSNMP,这个没有例子,不太好操作 一个是SnmpSharpNet,这个有些例子比较好, ...
- Tomcat 修改日志输出配置 定期删除日志
tomcat的下的日志catalina.out 和 qc.log疯狂增长,以下是解决办法 我生产环境tomcat版本 Server version: Apache Tomcat/7.0.35 Serv ...
- 软件bug描述(android)
1.bug主题:主要操作+bug主题 主题要简单明了,即开发一看主题就知道该问题. 2.描述: 作用:便于开发重现和定位缺陷的 2.1前置条件 2.2操作步骤 2.3预期结果 2.4实际结果 2.5备 ...
- 软链接和硬链接——Linux中的文件共享
硬链接(Hard Link)和软链接也称为符号链接(Symbolic Link)的目的是为了解决文件的共享使用问题.要阐明其原理,必须先理解Linux的文件存储方式. 索引结点 Linux是一个UNI ...
- 算法训练 最大获利 注意数据规模(long long)
资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 Chakra是一位年轻有为的企业家,最近他在进军餐饮行业.他在各地开拓市场,共买下了N个饭店.在初期的市场调研中,他将一天划分为M ...