反序列化: 将从 前端获取到的数据对象转化为 模型类字段,对其进行CRUD操作。
对 验证过程 和 保存过程 进行封装
数据来源:前端传递过来(接口中规定了前端传递的数据 --> 因为模型类中规定字段内容)
- 参数说明:
read_only = True:只参与反序列化过程,不参与序列化过程[get 无返回值 ]write_only = True:只参与序列化返回过程,不参与序列化返回过程[get 有返回值 参与验证和保存]max_length:最大长度min_length:最小长度min_value:最小值max_value:最大值default:默认值safe=False:
- 使用步骤
- 获取前端数据
- 验证数据
- 将数据传递给序列化器
ser = BookSerializer(data=data_dict)- 验证数据
ser.is_vaild(raise_exception=True)raise_exception=True:自动抛出错误ser.errors查看验证错误原因- 保存数据
ser.save()- 返回数据
- retuen JsonResponse(data, safe=False)
safe=False:
2.1 验证数据
在 序列化器中 定义验证方法
- 单一字段验证
def validate_字段名(self, value)value(接收字段为传递过来的字段)- 多个字段验证
def validate(self, attrs)attrs(接收字段为序列化器定义字段)注意:
raise serializers.ValidationError('提示信息')抛出错误信息is_valid()序列化器验证方法,执行is_valid() 是 会自动调用serializer中的validate_btitle(value) | validate(attrs)进行验证
2.2 保存数据
serializers.py在 序列化器 中创建create(validated_data)保存方法, 方法中书写保存业务逻辑 并且返回数据对象return bookviews.py中调用ser.save()
2.3 更新数据
- 接收前端传递的验证数据
- 查询更新哪个对象
book = BookInfo.objects.get(pk=id)- 将数据对象和要更新的数据对象,初始化传递给序列化器
ser=BookSerializer(book,data=book_dict)- 验证数据
ser.is_valid(raise_exception=True)- 序列化器调用
save()方法进行更新操作- 序列化结果返回
注意:
- 保存不需要传递数据对象
- 更新需要传递数据对象
- 保存和更新都是调用
save()方法, 更新操作update(instance, validated_date)和保存操作save(validated_date)传递的参数不一致update(instance, validated_date)中更新数据操作instance.btitle=validated_data['btitle']
模型类序列化器 ModelSerializer
ModelSerializer与常规的Serializer相同,但提供了:
- 基于模型类自动生成一系列字段
- 基于模型类自动为Serializer生成validators,比如unique_together
- 包含默认的create()和update()的实现
from rest_framework import serializers from .models import BookInfo class BookModelSerialize(serializers.ModelSerializer): """ serializer 高级用法 继承 ModelSerializer 自动生成模型类 """ # 显示指明字段 显示指定后的字段 # bcomment = serializers.IntegerField(max_value=1000, min_value=50) # 根据模型类生成序列化器字段 ---> python manage.shell 中查看 class Meta: model = BookInfo # model --> 根据哪个模型类生成 # 生成哪个字段 # fields = "__all__" # 返回所有字段 # fields = ('id', 'btitle') # 指定返回字段 exclude = ('bread', ) # 生成除了id btitle 字段外,取反操作 read_only_fields = ('bcomment',) # 增加read_only=True # 添加额外参数 extra_kwargs = { 'is_delete': { 'default': False } }
- 序列化器本质上就是一个类,将序列化和反序列化涉及到的方法封装起来
from rest_framework import serializers class Serialzier(serializers): # 验证方法 单一字段验证 多个字段验证 # 保存方法 create # 更新方法 update # 序列化方法 data