Django day26 HyperlinkedIdentityField,序列化组件的数据校验以及功能的(全局,局部)钩子函数,序列化组件的反序列化和保存...

一:HyperlinkedIdentityField(用的很少):传三个参数:第一个路由名字,用来反向解析,第二个参数是要反向解析的参数值,第三个参数:有名分组的名字

-1 publish = serializers.HyperlinkedIdentityField(view_name='ttt',lookup_field='publish_id',lookup_url_kwarg='pky')
-2 view_name:路由的别名,lookup_field:根据表的哪个字段,来拼路径,lookup_url_kwarg:反向解析有名分组的名字
-3 写路由:url(r'^publish/(?P<pky>\d+)', views.Publish.as_view(),name='ttt'),
-4 实例化序列化类的时候,需要把request对象传过去
book_ser=BookSerializer(ret,many=True,context={'request': request})

 xx=HyperlinkedIdentityField(view_name='路由名字',look_up_field='publish_id',lookup_url_kwarg='pky')

  xx=http://127.0.0.1:8001/publish/1

 
 

 

二:序列化组件的数据校验

   1、类比forms组件

   2、字段是否必填,通过required,来控制 authors=serializers.CharField(required=False)

   3、数据校验,生成一个序列化类的对象
      对象.is_valid()
   4、新增数据:
      对象.save()
   5、修改数据:
      在生成对象的时候,需要传instanse=查询出来的对象
      对象.save()

生成序列化类对象的时候,把要校验的数据(字典:前端传过来的)传过来
            ser=BookSerializer(data=request.data)
            ser.is_valid() 
            显示中文:error_messages={'required': '该字段必填'}

 

三:序列化组件数据校验功能的钩子函数

   1、局部钩子函数(value就是这个字段的值)

def validate_字段名(self, value):
                    #拿到值,就可以进行判断了
                    #如果通过,把value值返回,
                    #如果不通过,抛 ValidationError 异常

  2、全局钩子函数(value是验证通过的所有数据)

def validate(self, value):
                    #取出数据,进行判断
                    #如果通过,把value值返回,
                    #如果不通过,抛 ValidationError 异常

 

四:序列化组件的反序列化和保存

  1、保存

ser=BookSerializer(data=request.data)
ser.save()---->向数据库中插一条数据    

  2、更新

ser=BookSerializer(data=request.data.instance='要更新的对象')
ser.save()---->向数据库中插一条数据

 

转载于:https://www.cnblogs.com/zedong/p/10108265.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django中,序列化反序列化是指将数据转换为特定格式以便传输或存储,并将特定格式的数据转换为模型对象的过程。 在开发REST API接口时,序列化反序列化是非常重要的步骤。在视图中,我们需要将数据库中的数据序列化前端所需要的格式,并返回给前端;同时,我们也需要将前端发送的数据反序列化为模型类对象,并保存数据库中。这样可以方便地处理数据的传输和存储。[1] 在Django REST framework中,我们可以使用序列化器来定义数据序列化反序列化过程。序列化器是一个类,可以定义需要序列化反序列化的字段。例如,我们可以定义一个BookInfoSerializer序列化器,其中包含需要序列化反序列化的字段,如btitle、bpub_date和bread。[2] 在进行序列化时,如果要序列化的是包含多条数据的查询集QuerySet,可以通过添加many=True参数来说明。这样可以将查询集中的每个对象序列化为特定格式的数据,并返回一个包含所有序列化对象的列表。[3] 总结起来,序列化反序列化是在开发REST API接口时非常重要的步骤。通过序列化器,我们可以将数据库中的数据序列化前端所需要的格式,并返回给前端;同时,我们也可以将前端发送的数据反序列化为模型类对象,并保存数据库中。这样可以方便地处理数据的传输和存储。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值