python测试开发django-rest-framework-89.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=True
和 write_only=True
和 exclude
的区别了。