昨天,我们完成了Serializer序列化器的反序列化操作,那么今天我们就来学习Serializer序列化器的最后一点知识,反序列化操作。
首先,我们定要明确什么是反序列化操作?
反序列化操作:JOSN数据 --> 字典数据 -->验证通过的字典数据 --> 模型数据
我们在进行反序列化操作时,首先要保证就是拿到的字典数据一定要通过认证。
反序列化操作的步骤:
1. 定义一个序列化器(这里我们采用昨天定义好的序列化器即可)。
class BookInfoSerializer(serializers.Serializer): '''定义图书序Serializer序列化器''' # 这里的字段需要和模型类中的字段名、字段类型、约束一致 id = serializers.IntegerField(label='ID', read_only=True) btitle = serializers.CharField(label='名称', max_length=20) bpub_date = serializers.DateField(label='发布日期', required=False) bread = serializers.IntegerField(label='阅读量', required=False) bcomment = serializers.IntegerField(label='评论量', required=False)
2. 准备JSON数据或字典数据
data = { 'btitle':'大话西游','bpub_date':'2020-02-06'}
3. 验证字典数据
我们使用序列化器对象点出is_valid()方法进行验证,验证成功返回True,否则返回False。
3.1 验证通过
当字典数据通过校验时,我们可以通过序列化器对象点出validated_data属性获取到校验成功后的字典数据。
>>> data = { 'btitle':'大话西游','bpub_date':'2020-02-06'} >>> s = BookInfoSerializer(data=data) >>> s.is_valid() True >>> s.validated_data OrderedDict([('btitle', '大话西游'), ('bpub_date', datetime.date(2020, 2, 6))])
3.2 验证未通过
当字典数据未通过校验时,我们可以通过序列化器对象点出errors属性获取到错误信息。
>>> data = { 'bpub_date