反序列化: 将从 前端获取到的数据对象转化为 模型类字段,对其进行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 book
views.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