DRF_3 反序列化过程

反序列化: 将从 前端获取到的数据对象转化为 模型类字段,对其进行CRUD操作。

对 验证过程 和 保存过程 进行封装

数据来源:前端传递过来(接口中规定了前端传递的数据 --> 因为模型类中规定字段内容)

  1. 参数说明:
  • read_only = True:只参与反序列化过程,不参与序列化过程[get 无返回值 ]
  • write_only = True:只参与序列化返回过程,不参与序列化返回过程[get 有返回值 参与验证和保存]
  • max_length:最大长度
  • min_length:最小长度
  • min_value:最小值
  • max_value:最大值
  • default:默认值
  • safe=False
  1. 使用步骤
  1. 获取前端数据
  2. 验证数据
    1. 将数据传递给序列化器 ser = BookSerializer(data=data_dict)
    2. 验证数据 ser.is_vaild(raise_exception=True) raise_exception=True :自动抛出错误
    3. ser.errors 查看验证错误原因
  3. 保存数据
    • ser.save()
  4. 返回数据
    • retuen JsonResponse(data, safe=False) safe=False:

2.1 验证数据

序列化器中 定义验证方法

  1. 单一字段验证def validate_字段名(self, value) value(接收字段为传递过来的字段)
  2. 多个字段验证def validate(self, attrs) attrs(接收字段为序列化器定义字段)

注意:

  • raise serializers.ValidationError('提示信息') 抛出错误信息
  • is_valid() 序列化器验证方法,执行is_valid() 是 会自动调用serializer中的 validate_btitle(value) | validate(attrs) 进行验证

2.2 保存数据

  1. serializers.py 在 序列化器 中创建 create(validated_data) 保存方法, 方法中书写保存业务逻辑 并且返回数据对象return book
  2. views.py 中调用 ser.save()

2.3 更新数据

  1. 接收前端传递的验证数据
  2. 查询更新哪个对象 book = BookInfo.objects.get(pk=id)
  3. 将数据对象和要更新的数据对象,初始化传递给序列化器 ser=BookSerializer(book,data=book_dict)
  4. 验证数据 ser.is_valid(raise_exception=True)
  5. 序列化器调用 save() 方法进行更新操作
  6. 序列化结果返回

注意:

  • 保存不需要传递数据对象
  • 更新需要传递数据对象
  • 保存和更新都是调用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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容