Django的web框架Django Rest_Framework精讲(二)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: Django的web框架Django Rest_Framework精讲(二)

Django的web框架Django Rest_Framework精讲(一)https://developer.aliyun.com/article/1496739

4.序列化器的使用

在ser里面创建个新的模型类

添加几条数据



(1)创建序列化器

#先引入基础序列化器类

from rest_framework import serializers
from ser import models
"""
    name = models.CharField(max_length=100,verbose_name="姓名",help_text='提示文本:不能为空')
    sex = models.BooleanField(default=1,verbose_name="性别")
    age = models.IntegerField(verbose_name="年龄")
    class_null = models.CharField(max_length=5,verbose_name="班级编号")
    description = models.TextField(max_length=1000,verbose_name="个性签名")
"""

#这个基础序列化类,能指定哪个字段序列化什么格式,可以指定序列化哪些数据,加工几条数据,返回几条数据
# 序列化哪些字段,就写与模型类中相同的名称
class StudentSerializer(serializers.Serializer):
    id = serializers.IntegerField()
    name = serializers.CharField()
    sex = serializers.BooleanField()
    age = serializers.IntegerField()
    class_null = serializers.CharField()
    description = serializers.CharField()  #对于serializer中没有的数据类型,使用CharField。不写长度默认有多长序列化多长


这样的好处是,不想要哪个字段的数据,就不用序列化

视图类一样

from django.http import JsonResponse
from django.shortcuts import render

# Create your views here.

from django.views import View
from ser import models
from ser.serializers import StudentSerializer

class StudentView(View):
    def get(self,request):
        studentdata = models.Student.objects.filter()
        #序列化多条数据,需要加上many=True,返回序列化对象
        serializer_obj = StudentSerializer(instance=studentdata,many=True)
        #返回列表类型数据
        print(serializer_obj.data,type(serializer_obj.data))
        #JsonResponse返回非字典类型数据,需要加上safe=False,中文显示中文
        return JsonResponse(serializer_obj.data,safe=False, json_dumps_params={'ensure_ascii': False})

浏览器访问

上面我们序列化queryset类型数据,我们也可以序列化模型类对象

    #序列化模型类对象对于单条数据,不用加many=true
    studentdata = models.Student.objects.get(id=1)
    serializer_obj = StudentSerializer(instance=studentdata)   #返回字典

返回的是字典

注意:serializer不是只能为数据库模型类定义,也可以为非数据库模型类的数据定义。serializer是独立于数据库之外的存在。

常用字段类型:


选项参数

这个是在序列化类里面,在序列化相关字段时,可以添加一些参数

通用参数,默认required 默认是True


5. 反序列化器使用


序列化器的使用分两个阶段:


在客户端请求时,使用序列化器可以完成对数据的反序列化。

在服务器响应时,使用序列化器可以完成对数据的序列化。

使用序列化器进行反序列化时,需要对数据进行验证后,才能获取验证成功的数据或保存成模型类对象。


在获取反序列化的数据前,必须调用is_valid()方法进行验证,验证成功返回True,否则返回False。


验证失败,可以通过序列化器对象的errors属性获取错误信息,返回字典,包含了字段和字段的错误。如果是非字段错误,可以通过修改REST framework配置中的NON_FIELD_ERRORS_KEY来控制错误字典中的键名。


验证成功,可以通过序列化器对象的validated_data属性获取数据。


在定义序列化器时,指明每个字段的序列化类型和选项参数,本身就是一种验证行为。


后台收到前端发过来的数据,在保存之前要对数据进行校验,符合要求再往里面存

不符合要求报错

#定义个新的序列化器2,id是主键自增,不需要前端传递,所以不需要反序列化

# 数据校验基于用到了序列化时的参数,具体限制多少,要根据数据库创建时的要求来定
class StudentSerializer2(serializers.Serializer):
    name = serializers.CharField(max_length=8)
    sex = serializers.BooleanField()
    age = serializers.IntegerField()
    class_null = serializers.CharField()
    description = serializers.CharField()  #对于serializer中没有的数据类型,使用CharField。不写长度默认有多长序列化多长

反序列化器校验,基于用户提交的数据,再在视图函数写个post方法

  #用户提交数据逻辑
    def post(self,request):
        #保存数据之前要对用户提交的数据进行校验,将用户提交的数据放到序列化器中
        serializer_obj = StudentSerializer2(data=request.POST)
        #对数据进行校验,所有数据校验成功返回True,但凡有一个校验失败,返回False
        if serializer_obj.is_valid():
            print('校验成功后的数据',serializer_obj.validated_data)
            return JsonResponse(serializer_obj.validated_data,safe=False, json_dumps_params={'ensure_ascii': False})
        else:
            #打印校验失败信息
            print(serializer_obj.errors)
            #校验失败,返回错误信息,并修改状态码
            return JsonResponse({'error':'校验失败'},status=400)

我们借助接口调试工具postman或国产的apipost来调试

我们使用国产的apipost,可以设置请求类型,携带的请求参数

可以原生row的json类型提交,也可以form表单的www-form-urlencoded,form-data


apipost功能还是太少,我们使用postman

向后台传输原生json类型

注意,json 键和值如果是字符串类型,必须用英文双引号

最后一对键值对后面不能有逗号


后台打印可知,没接收到数据,因为Django默认解析不了json类型数据

一般情况下,需要我们通过request.body将数据取出来,然后自己手动序列化解析


现在我们通过DRF来帮我们自动解析,简化工作量

视图类继承drf的apiview from rest_framework.views import APIView

继承了APIView之后,视图类定义的请求方法中的request 就被重新加工了一遍


APIView类还是继承的View,对View进行了拓展

对View里面的request进行了扩展


扩展后的request,再从前端拿数据,不用request.POST了 使用request.data

request.data就能获取到前端post请求提交过来的json数据

不管什么格式,都能解析出来


request.data 返回解析后的请求体数据。类似Django中标准的request.POST和request.FILES属性,但是能提供如下属性

包含了解析后的文件和非文件数据

包含了对POST,PUT,PATCH请求方式解析后的数据

利用了REST framework的parsers解析器,不仅支持表单类型数据(unlencoded/data),也支持JSON数据(application/json)

此时,重启服务器,postman发送post请求


后台已经获取到,获取到的就是字典类型数据

当name字段长度超过限制,则会报错


查看打印的错误信息,code指明哪个参数校验报的错

发送符合要求的字段,就不再报错

现在我们发送个正确的post请求

返回正常的json类型数据


请求正常,就保存数据

allow_blank,默认为False, 空字符串 如果想要实现不传数据,需要结合required =False


validators校验函数

a).可以在序列化器字段上使用validators函数指定自定义的校验规则

b).validators值必须为序列类型(类表),在列表中可以添加多个校验规则

c).DRF框架自带的UniqueValidator校验器,必须指定queryset参数指定查询集对象,用于对该字段的唯一性进行校验,UniqueValidator里面还可以使用message指定自定义报错信息

    在序列化器需要反序列化输入校验的字段中,指定validators=[校验规则1,校验规则2...]参数,可以使用drf自带的校验规则UniqueValidator, 也可以使用自定义的的校验规则

error_messages 可以自定义报错信息 自定义错误信息用字典包裹,针对每个参数定义报错信息

发送post请求

这样,报错信息就是我们自定义的,实现了错误信息定制

不传name


上面序列化器,一个是用于序列化用的,一个是反序列化数据校验的,

序列化和反序列化 能不能合并成一个序列化器来使用呢?


可以的


针对个别字段,有的只用于序列化输出,有的只用于反序列化输入,可以用下面两个参数控制

read_only 表明该字段仅用于序列化输出,默认False 用户提交数据时,不校验该字段

write_only 表明该字段仅用于反序列化输入,默认False 序列化时不会把该字段提取出来,服务端响应数据时,不响应给客户端该字段。反序列化时,客户端必须要传该字段进行校验


序列化器合成一个

#将序列化和反序列化合并在一个序列化类中实现
class StudentSerializer3(serializers.Serializer):
    id = serializers.IntegerField(read_only=True)   #id在序列化时需要,反序列化时不需要
    name = serializers.CharField(max_length=8)
    sex = serializers.BooleanField()
    age = serializers.IntegerField(max_value=200)
    class_null = serializers.CharField()
    description = serializers.CharField()  #对于serializer中没有的数据类型,使用CharField。不写长度默认有多长序列化多长


视图类中,get请求和post请求,都用该序列化器

get请求,能收到数据

post请求,能提交数据


post请求校验成功



read_only使用场景:一般用在id上,序列化时需要,用户提交数据时不需要提交该字段

write_only使用场景:一般用在用户短信验证码,输入手机号,用户收到验证码,需要提交到后台验证,但是不需要服务端响应给客户,也不需要保存到数据库。


好了,今天先到这,明天继续,Carry on !

相关文章
|
16天前
|
数据采集 中间件 Python
如何在Django框架中进行输入验证和过滤?
通过综合运用这些方法,可以在 Django 框架中有效地进行输入验证和过滤,提高应用的安全性和数据质量。同时,还可以根据具体的业务需求进一步扩展和定制验证逻辑。
101 64
|
25天前
|
开发者 数据库管理 Python
Django框架和Flask框架的区别
总体而言,Django 适合需要快速搭建大型应用的开发者,而 Flask 则更适合有特定需求和追求灵活性的开发者。
109 64
|
1月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
162 45
|
16天前
|
监控 安全 测试技术
Django框架的表单验证和过滤机制是否可以应对复杂的安全场景?
综上所述,Django 框架的表单验证和过滤机制在一定程度上可以应对复杂的安全场景,但需要综合运用多种手段来进一步提升安全性,以适应不断变化的安全挑战。
26 1
|
23天前
|
搜索推荐 API 开发者
Django框架和Flask框架的适用场景分别是什么?
总体而言,Django 更适合需要全面功能和大规模开发的场景,而 Flask 则更适合灵活性要求高、小型项目或特定需求的开发。当然,具体的选择还应根据项目的具体情况、团队的技术能力和偏好等因素来综合考虑。在实际应用中,开发者可以根据项目的特点和需求,灵活选择使用这两个框架,或者结合它们的优势来构建更强大的 Web 应用程序。
|
23天前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
|
23天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
35 2
|
25天前
|
安全 前端开发 数据库
Django框架
总的来说,Django 是一个非常优秀的 Web 框架,它为开发者提供了坚实的基础和丰富的功能,使得构建高质量的 Web 应用变得更加容易和高效。无论是初学者还是经验丰富的开发者,都可以从中受益,利用它来实现自己的创意和想法。
38 4
|
29天前
|
Python
Django 框架的路由系统
Django 框架的路由系统
40 6
|
24天前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
63 1