zoukankan      html  css  js  c++  java
  • python测试开发django-rest-framework-89.反序列化(ModelSerializer)之read_only和write_only

    前言

    ModelSerializer 反序列化的时候,设置 read_only=True 可以忽略传过来的字段,不写入到数据库。
    那么从数据库读出来的数据,序列化返回出来的时候,不显示某个字段,可以设置write_only=True

    设置 read_only=True

    接着前面这篇https://www.cnblogs.com/yoyoketang/p/14342631.html
    不想让用户创建的时候设置下架,于是可以忽略 goods_status(商品状态) 字段, 设置 read_only=True

    # 作者-上海悠悠 QQ交流群:717225969
    # blog地址 https://www.cnblogs.com/yoyoketang/
    
    
    class GoodsSerializer(serializers.ModelSerializer):
        """序列化商品models"""
        create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S',required=False)
        update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S',required=False)
    
        # 必传字段
        goods_code = serializers.CharField(required=True)
        goods_stock = serializers.IntegerField(required=True)
    
        # 忽略字段,设置read_only=True
        goods_status = serializers.IntegerField(read_only=True)
    
        class Meta:
            model = Goods
            fields = '__all__'  # 返回全部的字段
    

    设置 write_only=True

    price是商品的成本价,用户在获取全部商品的时候,查询的时候不希望显示price,但是创建商品的时候,可以传price过去保存到数据库

    class GoodsSerializer(serializers.ModelSerializer):
        """序列化商品models"""
        create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
        update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
    
        # 必传字段
        goods_code = serializers.CharField(required=True,
                                           max_length=15,
                                           min_length=8,
                                           )
        goods_stock = serializers.IntegerField(required=True,
                                               min_value=1,
                                               max_value=10000)
        # 忽略字段,设置read_only=True
        goods_status = serializers.IntegerField(read_only=True)
        # 设置write_only=True
        price = serializers.FloatField(write_only=True)
    
        class Meta:
            model = Goods
            fields = '__all__'  # 返回全部的字段
    

    这时候查询的时候就不显示price

    但是创建商品的时候,price字段是可以被写入的

    查询数据库会看到已经写入到数据库了

    exclude 排除字段

    如果某个字段我们既不希望用户传到数据库,也不希望查询的时候显示给用户,那么可以用 exclude 排除字段的校验。

    如下排除 goods_groupid 商品分组字段的校验

    # 作者-上海悠悠 QQ交流群:717225969
    # blog地址 https://www.cnblogs.com/yoyoketang/
    
    
    class GoodsSerializer(serializers.ModelSerializer):
        """序列化商品models"""
        create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
        update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
    
        # 必传字段
        goods_code = serializers.CharField(required=True,
                                           max_length=15,
                                           min_length=8,
                                           )
        goods_stock = serializers.IntegerField(required=True,
                                               min_value=1,
                                               max_value=10000)
        # 忽略字段,设置read_only=True
        goods_status = serializers.IntegerField(read_only=True)
        # 设置write_only=True
        price = serializers.FloatField(write_only=True)
    
        class Meta:
            model = Goods
            # fields = '__all__'  # 返回全部的字段
            # exclude是不包含某些字段
            exclude = ["goods_groupid"]
    

    提交数据的时候,带上goods_groupid参数,并不会写入到数据库,也不会被查询出来

    通过本篇的学习也就弄清楚了read_only=Truewrite_only=Trueexclude的区别了。

  • 相关阅读:
    关于 未能加载文件或程序集“ImageMagickNet”或它的某一个依赖项。试图加载格式不正确的程序 的解决办法
    Nhibernate中 ManyToOne 中lazy="proxy" 延迟不起作用的原因
    关于mysqlconnectornet6.3.4 MySqlDataAdapter 在空数据的情况下填充DataSet后tables[0] 找不到的问题
    JavaScript:constructor属性
    关于AspNetPager 采用URL分页时 执行两次绑定的解决办法
    WPF学习笔记(一)
    unity3d 屏幕坐标、鼠标位置、视口坐标和绘制GUI时使用的坐标
    FileUpLoad用法(二)上传文件到服务器的数据库
    ASP.Net 使用GridView模板删除一行的用法
    ASP.Net FileUpLoad 控件的用法(一)——上传到服务器文件夹下
  • 原文地址:https://www.cnblogs.com/yoyoketang/p/14345717.html
Copyright © 2011-2022 走看看