序列化模块时rest-framework的很重要的组成部分
? 后台的数据多以后台的对象存在,经过序列化后,就可以格式化成能返回给前台的数据
? Serializer类(了解) --偏底层,开发效率不高
? ModelSerializer类(重中之重) --开发运用阶段才有的序列化方式,开发效率高
? ListSerializer类(正常) --完成群增,群改接口的辅助序列化类
ModelSerializer代码分析
#先导入ModelSerializer类
from rest_framework import ModelSerializer
# 自定义反序列化字段,校验规则只能在声明自定义反序列化字段时设置,且一定是write_only
re_pwd = serializers.CharField(min_length=3,max_length=64,writ_only=True)
#写一个类继承 ModelSerializer类 这里以User类为例
class UserModelSerializer(ModelSerializer):
re_pwd =
class Meta:
# 将序列化类与Model类进行绑定
models = model.User
# 1. 设置序列化与反序列化的所有字段(并划分序列化字段和反序列化字段 列表里面默认的是序列化和 反序列化都参与(在你的orm类中没有默认字段的情况下,如果有默认值或空,就不参与反序列化))
#2. 必须在orm中的字段 或者是自定义反序列化字段
fields = ['name','pwd','re_pwd','age','gender']
extra_kwargs = {
'name' :{
'required':True, #设置不能为空
'min_lenght':3, #设置最短不能短于三位
'error_messages':{ #自定义错误信息
'min_length':'用户名最短不能短于三位'
}
},
'age':{
'min_value':0 #设置最小值
},
'pwd':{
'required':True,
'write_only':True # 只参与反序列化
},
'gender':{
'read_only':True #只参与序列化
#如果orm类字段中存在 choices 类型
# 自定义插拔序列化字段:替换了在Serializer类中自定义的序列化字段 (SerializerMethodField)
# 自定义插拔序列化字段一定不参与反序列化过程
#@property
#def gender(self):
#return self.get_sex_display()
}
}
#局部钩子 使用 validata_字段名
def validata_name(self,value): #value = name的值
if 'g' in value.lower(): #判断name的值中是否存在g
raise serializer.ValidationError('报错信息') #如果不满足条件 就抛出错误信息
return value #这里值要返回出去
#全局钩子 判断两次密码是否一致
def validata(self.attrs) #attrs就是你列表字段里面的所有的值
pwd = attrs.get('pwd')
re_pwd = attrs.pop('re_pwd')
if pwd != re_pwd:
# 不一致 就抛异常
raise serializers.ValidationError({'re_pwd': '两次密码不一致'})
#返回attrs
return attrs
? 序列化与反序列功能可以整合成一个类,该类继承了ModelSerializer
继承ModelSerializer类的资源序列化类,内部包含三部分
Meta子类 局部钩子 全局钩子
注: create和update方法ModelSerializer已经重写了,使用不需要重写
在Meta子类中
重要的字段校验规则:
自定义序列化字段:在Model类中,定义方法属性(可以返回特殊值,还可以完成连表操作),在序列化类的fields属性中可以选择性插拔
自定义反序列化字段: 在Serializer类中,自定义校验字段,校验规则也只能在声明字段时设置,自定义的反序列化字段(如re_pwd),必须设置write_only为True
原文:https://www.cnblogs.com/kuck/p/11901903.html