0010 基于DRF框架开发(03 模型序列化器)
序列化器:是指从数据库提取数据,转化前端所需要的数据格式并返回到前端。
反序列化器:是指把前端传回的数据,转换成数据库需要的格式,存入数据库。
DRF提供了两种序列化器:
模型序列化器:是指和模型关联的序列化器,需要引入模型来定义序列化器。
普通序列化器:是指和模型无关的序列化器,和模型无关,只是一个序列化器。
本节主要介绍模型序列化器
1 创建模型序列化器
在Applications/Examples/views下创建文件,名为:Schools.py
from rest_framework import serializers
from Applications.Examples.models import Schools
from rest_framework.viewsets import ModelViewSet
import re class SchoolsSerializer(serializers.ModelSerializer):
"""
【功能描述】模型序列化器,主要针对模型生成的序列化器。
1 临时字段
模型序列化器中可定义临时字段,用于上传用户数据,或下发从其它模型或内存中的数据。
如果上传临时字段,则设置为write_only=True
如果下发临时字段,则设置为read_only=True
2 重新定义模型字段
对于模型中已存在的字段,可以在此重新定义约束。如:手机号,座机号,可以用正则表达式来定义。
"""
# 手机验证码是用于前端上传的,而不需要后端下发,故定义write_only=True
sms_code = serializers.CharField(min_length=6, max_length=6, write_only=True, help_text='手机验证码') class Meta:
"""
【功能描述】
1 指定模型名
2 指定需要上传或下载的模型字段名
如果所有字段全部选择,则使用fields = '__all__'
如果手工指定字段,则用元组列出要指定的字段名
"""
model = Schools
fields = ('id', 'name', 'email', 'phone', 'employment_rate', 'sms_code', 'teacher_quantity', 'student_quantity')
extra_kwargs = {
'id': {
'read_only': True, # 用户ID是只读的,故只能读取不能填写
'help_text': '学校ID'
},
'name': {
'help_text': '学校名',
'min_length': 2,
'max_length': 10,
'error_messages': {
'min_length': '用户名不能少于两个中文字符',
'max_length': '用户名不能大于20个中文字符',
},
},
'employment_rate': {
'help_text': '就业率(%)',
} } @classmethod
def validate_phone(cls, value):
"""
【功能描述】用于验证某个字段,则用'validate_'+字段名来命名函数,validate_<field_name>
"""
if not re.match(r'\(?0\d{2,3}[)-]?\d{7,8}', value): # 正则表达式匹配座机号
raise serializers.ValidationError('不是有效的座机号')
return value @classmethod
def validate_employment_rate(cls, value):
"""
【功能描述】用于验证某个字段,则用'validate_'+字段名来命名函数,validate_<field_name>
"""
if value > 100:
raise serializers.ValidationError('就业率不能超过100%')
if value < 0:
raise serializers.ValidationError('就业率不能小于0%')
return value @classmethod
def validate_sms_code(cls, value):
"""
【功能描述】用于处理接收的临时字段,比如验证码是否过期等操作。验证完后,在保存前要删除临时字段。
"""
return value @classmethod
def validate(cls, attrs):
"""
【功能描述】用于同时验证多个字段
"""
if attrs['teacher_quantity'] <= 0:
raise serializers.ValidationError('教师人数不能小于等于0')
if attrs['student_quantity'] <= 0:
raise serializers.ValidationError('学生人数不能小于等于0')
if attrs['teacher_quantity'] >= attrs['student_quantity']:
raise serializers.ValidationError('教师人数不能大于等于学生人数')
return attrs def create(self, validated_data):
del validated_data['sms_code'] # 临时字段仅用于上传,保存数据库之前要删除
return Schools.objects.create(**validated_data) def update(self, instance, validated_data):
"""
【功能描述】用于处理只更新部分字段的情况
"""
instance.name = validated_data.get('name')
# Email允许为空,前端可传可不传,如果传了,则修改,如果没传,则维持原数据
if validated_data.get('email'):
instance.email = validated_data.get('email')
instance.phone = validated_data.get('phone')
instance.employment_rate = validated_data.get('employment_rate')
instance.teacher_quantity = validated_data.get('teacher_quantity')
instance.student_quantity = validated_data.get('student_quantity')
instance.save()
return instance class SchoolsViewSet(ModelViewSet):
queryset = Schools.objects.all()
serializer_class = SchoolsSerializer
2 增加视图
class SchoolsViewSet(ModelViewSet):
queryset = Schools.objects.all()
serializer_class = SchoolsSerializer
3 增加路由
在Examples分路由urls.py中增加一个路由:
router.register('Schools', SchoolsViewSet) # 向路由器中注册视图集
4 运行工程,测试自动生成的所有接口。共六个接口,页面如下:

0010 基于DRF框架开发(03 模型序列化器)的更多相关文章
- 0012 基于DRF框架开发(04 序列化器的字段与选项)
1 常用字段类型 字段 构造方式 BooleanField BooleanField() NullBooleanField NullBooleanField() CharField CharField ...
- 0009 基于DRF框架开发(02 创建模型)
上一节介绍了DRF开发的基本流程,共五个步骤: 1 创建模型 2 创建序列化器 3 编写视图 4 配置URL 5 运行测试 本节主要讲解创建模型. 构建学校,教师,学生三个模型,这三个模型之间的关系是 ...
- 0011 基于DRF框架开发(04 普通序列化器)
普通序列化器和模型无关,只是对针对提交字段的定义. 本文定义三个序列化器: 教师序列化器,学生序列化器,教师学生序列化器.这三个序列化器都使用普通序列化器. 1 教师序列化器 在Application ...
- 0013 基于DRF框架开发(01 基类视图 APIView)
之前学习了模型序列化和普通序列化,我们用最简单的视图和url实现了对序列化的操作. 而实际上,象之前那种由DRF自动生成所有的视图和url的情况,在应用是使用很少.而需要用户根据实际业务需求,自定义视 ...
- 0008 基于DRF框架开发(01 DRF开发的基本流程)
1 创建模型 由于之前在<004 工程配置>中,已在Applications/Organizations/models中创建了一个UserInfo模型.此处引用这个模型. from dja ...
- 0014 基于DRF框架开发(02 基类视图 GenericAPIView)
前端于对数据操作的请求基本上就分为四类:增删改查,即增加.删除.修改.查询. 而DRF把前端请求分为两个大类:带ID参数请求和不带ID参数请求. 不带ID参数请求包括:增加.分布多条查询 带ID参数请 ...
- MapReduce教程(一)基于MapReduce框架开发<转>
1 MapReduce编程 1.1 MapReduce简介 MapReduce是一种编程模型,用于大规模数据集(大于1TB)的并行运算,用于解决海量数据的计算问题. MapReduce分成了两个部分: ...
- 基于SSH框架开发的《高校大学生选课系统》的质量属性的实现
基于SSH框架开发的<高校大学生选课系统>的质量属性的实现 对于可用性采取的是错误预防战术,即阻止错误演变为故障:在本系统主要体现在以下两个方面:(1)对于学生登录模块,由于初次登陆,学生 ...
- 基于NopCommerce框架开发的微信小程序UrShop
Urshop小程序商城 介绍 UrShop小程序商城 2.0发布啦,发布地址https://gitee.com/urselect/urshop UrShop 根据NopCommerce框架开发的,基于 ...
随机推荐
- Trie(字典树)的侃侃
Trie是什么 ? 字典树 : 见名知意(在树上进行查询). 跟字典相关的必定与查询有密切的关系, 查询就需要一定的媒介作为支撑,树就为这种查询提供支撑. Trie做什么 ? 实现字符串快速检索的多叉 ...
- JMeter之If Controller深究二
1.背景 接上文JMeter之If Controller深究一,在上文中提到压测采用的是JMeter3.1版本,本篇继续深究.基本确定问题原因后,宝路这边又做了不同版本的JMeter对比实验,这次加入 ...
- Hapi+MySql项目实战数据库操作(四)
数据库访问 下面以Node的ORM框架Sequelize来操作数据库,Mysql为例. 配置数据库连接信息config/db_config.js: //db_config.js module.expo ...
- Hapi+MySql项目实战路由初始化(二)
配置路由规则 将路由文件放在routes文件夹里,修改‘Server.js’文件,增加如下代码: 我们这里指明了require('./routes') routes文件夹,require可以文件但是不 ...
- Python - with open()、os.open()、open()的详细使用
读写文件背景 读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘. 读写文件就是请求 ...
- CentOS 7的yum更换为国内的阿里云yum源
Yellow dog Updater(Yum)是CentOS所有版本的默认包管理器,yum主要功能是更方便的添加/删除/更新RPM包,自动解决包的依赖性问题,便于管理大量系统的更新问题,其理念是使用一 ...
- Samba搭建Linux和Windows文件共享服务
一.Samba简介 Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成.SMB(Server Messages Block,信息服务块)是一种在局域网上共享 ...
- Windows+Python+Selenium基础篇之1-环境搭建
1.所需工具包1.1Selenium for python1.2 Python 1.3 Notepad++或python IDE 2. 环境搭建2.1 下载和安装Pythonpython2. ...
- FakeLogonScreen抓取Windows凭证
FakeLogonScreen抓取Windows凭证 实践中使用的配置 攻击者: 操作系统: Kali Linux 2020.1 IP: 192.168.1.13 目标: 作业系统: Windows ...
- 解决关闭SSH进程CobaltStrike自动关闭
解决关闭SSH进程CobaltStrike自动关闭 0x0 那么为什么ssh一关闭,程序就不再运行了? 答:元凶:SIGHUP 信号 让我们来看看为什么关掉窗口/断开连接会使得正在运行的程序死掉. 在 ...