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的区别了。

posted @   上海-悠悠  阅读(980)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2019-01-29 python测试开发django-13.ORM操作数据库(增删改查)
点击右上角即可分享
微信分享提示