目录

一 什么是序列化

二 Django REST framework配置流程之Serializer

三 Django REST framework配置流程之ModelSerializer

一 什么是序列化

序列化模型与序列化关系模型

序列化模型,顾名思义,即对 models 里的数据模型作序列化。

而序列化关系模型则是对 models 里数据模型中带有关系的如 ForeignKey, ManyToManyField 和 OneToOneField 字段作序列化。

Django Rest Framework 提供了灵活的序列化关系模型,让开发者可以自由定制序列化数据模型。

二 Django REST framework配置流程之Serializer

1、GET请求

  1. 写一个序列化的类,这个类需要继承Serializer,一对多字段可以直接通过指定source字段来查找。如果是多对多的字段则需要做进一步处理才能在页面显示
from rest_framework import serializers
class UserInfoSerializer(serializers.Serializer):
name = serializers.CharField(max_length=32)
pwd = serializers.CharField(max_length=128)
# 多对多跨表查询,查询到的是所有对象
been_city = serializers.CharField(source="been_city.all")
  1. 视图函数的配置
class IndexView(APIView):

    def get(self, request):
user_list = models.UserInfo.objects.all()
# 获取到的是一个serializer对象,如果user_list是一个对象则不需要many=True
ser = UserInfoSe rializer(instance=user_list, many=True)
# print(ser)
"""
UserInfoSerializer(instance=<QuerySet []>, many=True):
name = CharField(max_length=32)
pwd = CharField(max_length=128)
been_city = CharField(source='city.name')
"""
# ser.data是一个有序字典
return Response(ser.data)
  1. 启动项目访问url,可以看到多对多字段只能显示object

  2. 处理多对多字段的显示

    a) 方法一:重写CharField的to_representation方法,这个方法就是用来显示最终数据的

class MyCharField(serializers.CharField):
def to_representation(self, value):
# value就是QuerySet对象列表
data_list = []
for row in value:
data_list.append({'name': row.name, 'province': row.province.name})
return data_list class UserInfoSerializer(serializers.Serializer):
name = serializers.CharField(max_length=32)
pwd = serializers.CharField(max_length=128)
# 通过自定义的MyCharField中的to_representation处理多对多字段的QuerySet对象
been_city = MyCharField(source="been_city.all")

 b) 方法二:通过ListField方法

class MyCharField(serializers.CharField):
def to_representation(self, value):
# value就是每个QuerySet对象 return {‘id’:value.pk, "name": value.name, "province":value.province.name} class UserInfoSerializer(serializers.Serializer):
name = serializers.CharField(max_length=32)
pwd = serializers.CharField(max_length=128)
# 通过自定义的MyCharField中的to_representation处理多对多字段的QuerySet对象
been_city = serializers.ListField(child=MyCharField(),source="been_city.all")

 c) 方法三:通过定义serializers.SerializerMethodField()可以生成对象列表,然后通过get方法,可以接收对象,并返回需要的json数据

class UserInfoSerializer(serializers.Serializer):
name = serializers.CharField(max_length=32)
pwd = serializers.CharField(max_length=128)
# 多对多跨表查询,查询到的是所有city对象
# been_city = serializers.CharField(source="been_city.all")
# print(been_city)
# provinse = serializers.CharField(source="been_city.province")
been_city = serializers.SerializerMethodField() # 获取到的是UserInfo对象 def get_been_city(self, obj):
print(obj)
city_list = obj.been_city.all()
data_list = []
for row in city_list:
data_list.append({'name': row.name, 'province': row.province.name})
return data_list

源码浏览

访问URL效果

2、POST请求

  1. 数据验证配置
class PasswordValidator(object):
def __init__(self, base):
self.base = base
def __call__(self, value):
if value != self.base:
message = '用户输入的值必须是 %s.' % self.base
raise serializers.ValidationError(message)
class UserInfoSerializer(serializers.Serializer):
name = serializers.CharField(max_length=32)
pwd = serializers.CharField(max_length=128, error_messages={'required': '密码不能为空'},
validators=[PasswordValidator('666'), ]
  1. 在视图函数里面写post方法,并且根据用户发送的数据做序列化操作
class IndexView(APIView):
def post(self, request):
# 接收POST数据
data = request.POST
# 序列化数据,基于Serializer和ModelSerializer都可以
# ser = UserInfoSerializer(data=data, many=True)
ser = UserInfoModelSerializer(data=data, many=True)
# 判断数据是否符合要求
if ser.is_valid():
print(ser.validated_data) # OrderedDict([('name', 'jack'), ('pwd', '123')])
# models.UserInfo.objects.create(**ser.validated_data)
return Response('添加成功')
return Response("POST测试")

三 Django REST framework配置流程之ModelSerializer

1、基础配置实例

class UserInfoSerializer(serializers.ModelSerializer):
class Meta:
# model表
model = models.UserInfo
fields = '__all__'
# fields = [] # 可以指定字段
# 遍历的深度
depth = 2

2、自定义简单字段实例配置

class UserInfoSerializer(serializers.ModelSerializer):
# 可以通过serializers自定义字段
xxx = serializers.CharField(source="name")
class Meta:
# model表
model = models.UserInfo
fields = '__all__'
# fields = [] # 可以指定字段
# 遍历的深度
depth = 2

3、基于HyperlinkedRelatedField实现url的实例配置

class UserInfoSerializer(serializers.ModelSerializer):
#view_name是用来反向生成url的
xxx = serializers.HyperlinkedRelatedField(view_name="detail")
class Meta:
# model表
model = models.UserInfo
fields = '__all__'
# fields = [] # 可以指定字段
# 遍历的深度
depth = 2
# urls.py配置
urlpatterns = [
# 由于在class HyperlinkedRelatedField(RelatedField)中定义了lookup_field="pk",
# 所以在url中必须使用pk字段
url(r'xxx/(?P<pk>\d+)', views.UserView.as_view(), name='detail'),
]
# UserView配置
class UserView(APIView):
def get(self, request):
user_list = models.UserInfo.objects.all()
ser = UserSerializer(instance=user_list, many=True, content={"request":request})
return Response(ser.data)

4、全部生成url(serializers.HyperlinkedModelSerializer会把每个字段都成条url,默认的view_name是userinfo-detail

class ModelUserSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = models.UserInfo
fields = '__all__' # 生成url
# fields = ['name', 'pwd'] # 只显示字段
# exclude = ['role',]
# urls.py配置
urlpatterns = [
url(r'^xxx/(?P<pk>\d+)', view.UserView.as_view(), name='userinfo-detail'),
url(r'^xxx/(?P<pk>\d+)', view.UserView.as_view(), name='group-detail'),
url(r'^xxx/(?P<pk>\d+)', view.UserView.as_view(), name='role-detail'),
]

Django Rest framework序列化流程的更多相关文章

  1. Django Rest framework实现流程

    目录 一 什么是restful架构 二 Django REST framework简介 三 Django REST framework原理 四 Django REST framework源码流程 五 ...

  2. Django REST Framework序列化器

    Django序列化和json模块的序列化 从数据库中取出数据后,虽然不能直接将queryset和model对象以及datetime类型序列化,但都可以将其转化成可以序列化的类型,再序列化. 功能需求都 ...

  3. [Django REST framework - 序列化组件、source、钩子函数]

    [Django REST framework - 序列化组件.source.钩子函数] 序列化器-Serializer 什么是rest_framework序列化? 在写前后端不分离的项目时: 我们有f ...

  4. Django REST framework序列化

    一.简介 Django REST framework是基于Django实现的一个RESTful风格API框架,能够帮助我们快速开发RESTful风格的API. 官网:https://www.djang ...

  5. 02 Django REST Framework 序列化

    01-创建序列化类 # 方式一: publish_list = models.Publish.objects.all() # 导入序列化组件 from django.core import seria ...

  6. Django Rest Framework 请求流程

    用户请求到django,首先经过wsgi,中间件,然后到url路由系统,执行视图类中继承APIView执行as_view方法,在源码中可以看到VPIView继承了django的View类,通过supe ...

  7. python学习-- Django REST framework 序列化数据操作

    一.为什么要返回json数据? 一般来说前端要用到从后台返回的数据来渲染页面的时候,这时候后台就需要向前端返回json类型的数据,简单直观便于理解 ,就类似于 {"xxx":{[& ...

  8. Django REST Framework 序列化和校验 知识点

    DRF序列化 Django ORM对象 --> JSON格式的数据 序列化 JSON格式的数据 --> Django ORM数据 反序列化 需要两个工具: from rest_framew ...

  9. django rest framework 序列化组件总结

    序列化组件总结 一. 序列化组件本质上为了实现前后端分离,而进行json序列化的一个组件形式,极大方便了解析数据的作用 二. 所有序列化是基于APIView 解析器实现的,通过内部的多继承关系方便实现 ...

随机推荐

  1. Mapbox显示地图案例

    mapbox地图入门案例 <!DOCTYPE html> <html> <head> <meta charset='utf-8' /> <titl ...

  2. Angular常用命令:

    新建项目: ng new angualrdermo08 --skip-install 创建需要的组件: ng g component home

  3. 深入学习c++--多线程编程(一)

    1. 简介 2. 线程使用 2.1 demo #include <iostream> #include <thread> #include <future> usi ...

  4. 【Java】阿里巴巴Java开发手册

    阿里巴巴Java开发手册 下载地址:https://github.com/alibaba/p3c 阿里巴巴代码规范检查插件p3c 下载地址:https://github.com/alibaba/p3c

  5. Oracle中Sequence使用

    Oracle提供了sequence对象,由系统提供自增长的序列号,通常用于生成数据库数据记录的自增长主键或序号的地方. 下面介绍一下关于sequence 的生成,修改,删除等常用的操作: 1. 创建 ...

  6. (二十三)IDEA 构建一个springboot工程,以及可能遇到的问题

    一.下载安装intellij IEDA 需要破解 二.创建springboot工程 其他步骤省略,创建好的工程结构如下图: 三.配置springoboot工程 3.1 如上图src/main目录下只有 ...

  7. Swift4.0复习Optional

    1.Optional基本使用: 当我们声明一个Optional对象时,无论该对象是在文件作用域还是在函数体内作为局部对象声明,如果不对它初始化,那么它的值默认为空(nil). // 声明a为Int类型 ...

  8. Jmeter学习——测试计划元件【转】

    1. Test Plan (测试计划) 用来描述一个性能测试,包含与本次性能测试所有相关的功能.也就说本次性能测试的所有内容是于基于一个计划的. 下面看一下一个计划下面都有哪些主要的功能模块(右键单击 ...

  9. union all 关键字的应用(合并两个查询结果集到同一个结果集)

    在此对于数据库中 union all 关键字的功能和用法进行简单的使用介绍. 这是我工作中的一个需求: 有两个 A表 和B表. A表的数据: B表的数据: 现在有这样一个需求,让他一次性的全部查出来. ...

  10. php有关类和对象的相关知识1

    有关类和对象的相关知识 类的自动加载 类的自动加载是指,在外面的页面中,并不需要去“引入”(包含)类文件,但是程序会在需要一个类的时候就自动去“动态加载”该类. 什么叫做“需要一个类”?通常是这样的情 ...