首页 > 其他分享 >Django-restframework 序列化器与反序列化器

Django-restframework 序列化器与反序列化器

时间:2023-01-04 20:33:12浏览次数:45  
标签:serializers 验证 True Django restframework 序列化 data serializer

序列化器

restframework中提供了所有可用的序列化器基类,引用方法如下:

from rest_framework import serializers

Serializer:序列化器基类,drf中所有的序列化器都必须继承于Serializer

ModelSerializer:模型序列化器基类,是序列化器基类的子类,在工作中,除了Serializer基类之外,最常用的序列化器基类。

转换字段声明

class StudentSerializer(serializers.Serializer):
    """ 学生信息序列化器 """
    # 1. 转换的字段声明
    id = serializers.IntegerField()
    name = serializers.CharField()
    sex = serializers.BooleanField()
    age = serializers.IntegerField()
    description = serializers.CharField()

编写视图类

from django.http import JsonResponse
from django.views import View
from .serializers import StudentSerializer
from students.models import Student

class StudentView(View):
    def get(self, request):
        """ 序列化器,序列化阶段的调用 """
        student_list = Student.objects.all()
        # 1. 实例化序列化器,得到序列化对象
        serializer = StudentSerializer(instance=student_list, many=True)

        # 2. 调用序列化对象的data属性方法获取转换后的数据
        data = serializer.data

        # 3. 响应数据
        return JsonResponse(data=data, status=200, safe=False, json_dumps_params={"ensure_ascii": False})

通过many=True,可以查询到多个模型对象。下面演示查询一个模型对象的例子:

from django.http import JsonResponse
from django.views import View
from .serializers import StudentSerializer
from students.models import Student

class StudentView(View):
    def get(self, request):
        """ 序列化器,序列化阶段的调用 """
        student = Student.objects.first()
        # 1. 实例化序列化器,得到序列化对象
        serializer = StudentSerializer(instance=student, many=True)

        # 2. 调用序列化对象的data属性方法获取转换后的数据
        data = serializer.data

        # 3. 响应数据
        return JsonResponse(data=data, status=200, safe=False, json_dumps_params={"ensure_ascii": False})

如果序列化器的模型对象是多个,务必使用many=True

绑定路由

from .import views
from django.urls import path
urlpatterns = [
    path("students", views.StudentView.as_view())
]

反序列化

使用序列化器进行反序列化时,需要对数据进行验证后,才能获取验证成功的数据或保存成模型类对象。
在获取反序列化的数据前,必须调用is_valid()方法进行验证,验证成功返回True,否则返回False。
验证失败,可以通过序列化器对象的errors属性获取错误信息,返回字典,包含了字段和字段的错误。如果是非字段错误,可以通过修改Rest Framework配置中的NON_FIELD_ERRORS_KEY来控制错误字典中的键名。
验证成功,可以通过序列化器对象的validated_data属性获取数据。
在定义序列化器时,指明每个字段的序列化类型和选项参数,本身就是一种验证行为。

转换字段声明

class StudentSerializer(serializers.Serializer):
    """ 学生信息序列化器 """
    # 1. 转换的字段声明
    id = serializers.IntegerField(read_only=True) # 在客户端提交数据(反序列化阶段不会要求id字段)
    name = serializers.CharField(required=True) # 反序列化阶段必填
    sex = serializers.BooleanField(default=True) # 反序列化阶段,客户端没有提交,则默认为True
    age = serializers.IntegerField(max_value=50, min_value=6, error_messages={
        "min_value": "最小值不能低于1",
        "max_value": "最大值不能大于50"
    })
    description = serializers.CharField(allow_null=True, allow_blank=True)

可以在这里面通过error_message来定义验证错误时返回的信息。

编写视图类

class StudentView(View):

    def get(self, request):
        """ 反序列化-采用字段选项来验证数据"""
        # 接收客户端提交的数据
        # data = json.dumps(request.body)
        # 模拟客户端的数据
        data = {
            "name": "xiaohong",
            "age": 0,
            "sex": True,
            "classmate": 301,
            "description": "这家伙很懒,什么都没留下!"
        }
        # 实例化序列化器,获取序列化对象
        serializer = StudentSerializer(data=data)

        # 调用序列化器进行数据验证
        ret = serializer.is_valid()
        # 获取验证以后的结果
        if ret:
            print(serializer.validated_data)
            return JsonResponse(dict(serializer.validated_data))
        else:
            print(serializer.errors)
            return JsonResponse(dict(serializer.errors))

下面是一种工作中更为常用的写法,即抛出异常:

class StudentView(View):

    def get(self, request):
        """ 反序列化-采用字段选项来验证数据"""
        # 接收客户端提交的数据
        # data = json.dumps(request.body)
        # 模拟客户端的数据
        data = {
            "name": "xiaohong",
            "age": 0,
            "sex": True,
            "classmate": 301,
            "description": "这家伙很懒,什么都没留下!"
        }
        # 实例化序列化器,获取序列化对象
        serializer = StudentSerializer(data=data)

        # 调用序列化器进行数据验证
        ret = serializer.is_valid(raise_exception=True)
        # 获取验证以后的结果
        return JsonResponse(dict(serializer.validated_data))

验证对象方法

自己编写对字段进行逻辑校验。

class StudentSerializer(serializers.Serializer):
    """ 学生信息序列化器 """
    # 1. 转换的字段声明
    id = serializers.IntegerField(read_only=True) # 在客户端提交数据(反序列化阶段不会要求id字段)
    name = serializers.CharField(required=True) # 反序列化阶段必填
    sex = serializers.BooleanField(default=True) # 反序列化阶段,客户端没有提交,则默认为True
    age = serializers.IntegerField(max_value=50, min_value=6, error_messages={
        "min_value": "最小值不能低于1",
        "max_value": "最大值不能大于50"
    })
    description = serializers.CharField(allow_null=True, allow_blank=True)
    # 2. 如果当前序列化器继承的是ModelSerializer,则需要声明调用的模型信息

    # 3. 验证代码的对象方法
    def validate(self, attrs):
        """
        验证来自客户端的所有数据
        validate是固定方法名
        attrs:是在序列化器实例化时data选项数据
        """
        # 307班只能有女生,不能加入其他男生
        if attrs['classmate'] == 307 and attrs['sex']:
            raise serializers.ValidationError(detail='307班只能有小姐姐哦~', code='validate')


    def validate_name(self, data):
        """ 验证单个字段 """
        print(data)
        if data in ['python', 'django']:
            # 在序列化器中验证失败,可以通过抛出异常的方式来告知
            raise serializers.ValidationError(detail='学生姓名不能为python或django')
        # 验证成功必须返回data数据
        return data

模型操作方法

class StudentSerializer(serializers.Serializer):
    """ 学生信息序列化器 """
    # 1. 转换的字段声明
    id = serializers.IntegerField(read_only=True)  # 在客户端提交数据(反序列化阶段不会要求id字段)
    name = serializers.CharField(required=True)  # 反序列化阶段必填
    sex = serializers.BooleanField(default=True)  # 反序列化阶段,客户端没有提交,则默认为True
    age = serializers.IntegerField(max_value=50, min_value=6, error_messages={
        "min_value": "最小值不能低于1",
        "max_value": "最大值不能大于50"
    })
    classmate = serializers.CharField(required=True)
    description = serializers.CharField(allow_null=True, allow_blank=True)

    # 4. 模型操作的方法
    def create(self, validated_data):
        """ 完成添加操作,添加数据以后,就自动实现了从字段变成对象的过程"""
        return Student.objects.create(**validated_data)

    def update(self, instance, validated_data):
        """ 更新数据操作 """

        instance.name = validated_data["name"]
        instance.age = validated_data["age"]
        instance.sex = validated_data["sex"]
        instance.classmate = validated_data["classmate"]
        instance.description = validated_data["description"]
        instance.save()
        return instance

在视图类中定义添加与修改的操作:

class StudentView(View):
    def get(self, request):
        pk = 5
        try:
            student = Student.objects.get(pk=pk)
        except:
            return JsonResponse({"errors": "未查询到此人"}, status=404)

        # 模拟客户端的数据
        data = {
            "name": "xiaoming",
            "age": 17,
            "sex": True,
            "classmate": "301",
            "description": "这家伙很懒,什么都没留下!"
        }

        serializer = StudentSerializer(instance=student, data=data)

        serializer.is_valid(raise_exception=True)

        serializer.save()
        return JsonResponse(serializer.data, status=201)
    def get5(self, request):
        # 模拟客户端的数据
        data = {
            "name": "xiaohong",
            "age": 16,
            "sex": True,
            "classmate": "301",
            "description": "这家伙很懒,什么都没留下!"
        }
        # 实例化序列化器,获取序列化对象
        serializer = StudentSerializer(data=data)

        # 调用序列化器进行数据验证
        serializer.is_valid(raise_exception=True)

        # 获取验证以后的结果,操作数据库
        serializer.save()
        return JsonResponse(dict(serializer.validated_data))

标签:serializers,验证,True,Django,restframework,序列化,data,serializer
From: https://www.cnblogs.com/Gazikel/p/17024220.html

相关文章

  • django时区问题的解决
    django时区问题的解决 更新时间:2021年05月18日09:37:58 作者:Silent丿丶黑羽  我们都知道时区,标准时区是UTC时区,django默认使用的就是UTC时区,我们希望存储在数据......
  • Django 03
    https://docs.djangoproject.com/en/4.1/intro/tutorial03/fromdjango.urlsimportpathfrom.importviewsapp_name='polls'urlpatterns=[path('',views.......
  • django 如何提升性能(高并发)
    django如何提升性能(高并发)对一个后端开发程序员来说,提升性能指标主要有两个一个是并发数,另一个是响应时间网站性能的优化一般包括web前端性能优化,应用服务器性能优化,存......
  • django中间件补充、django操作cookie与session
    django中间件补充、django操作cookie与session目录django中间件补充、django操作cookie与session基于django中间件实现功能的插拔式设计cookie与session简介django操作coo......
  • ArcObjects SDK开发 025 AO中对象的序列化和反序列化
    在ArcObjectsSDK,序列化接口是IPersistStream,该接口的定义如下。其中GetClassID函数可以获取实际类型的唯一ID,Load函数是反序列化函数,Save函数为序列化函数。我们看下Loa......
  • 问题:django.template.exceptions.TemplateSyntaxError: 'staticfiles' is not a regis
     django使用swagger自动生成API文档时,报错  解决方法: 在settings.py里面配置一下以下代码'libraries':{'staticfiles':'django.templatetags.static'......
  • python中数据类型与json的序列化和反序列
    |JSON|Python||-------------------|------------||object|dict(集合)||array|list列......
  • 如何创建Django项目
    创建Django项目前置条件:已完成Python环境和PyCharm安装|在命令行输入pip命令安装pipinstall-ihttps://pypi.douban.com/simpledjango或指定相应的django版本:......
  • Django-restframework
    环境安装与配置DRF需要以下依赖:Python(3.5以上)Django(2.2以上)DRF是以Django子应用的方式提供的,所以我们可以直接利用已有的Django环境而无需重新创建。安装DRF......
  • Django 1.3
    https://docs.djangoproject.com/en/4.1/intro/tutorial02/Django的文档看到了02,其中有个很有意思的地方,就是用这个命令pythonmanage.pymigrate框架他会给你一些生成......