serializers 序列化器里面进行 校验等
一.第一版(一般不用)
# 声明序列化器from rest_framework import serializersfrom djangoDome.models import Book class PublisherSerializer(serializers.Serializer): id = serializers.IntegerField() title = serializers.CharField(max_length=32) class AuthorSerializer(serializers.Serializer): id = serializers.IntegerField() name = serializers.CharField(max_length=32) #自定义字段def my_validate(value): if 'xxoo' in value.lower(): #抛敏感词汇 raise serializers.ValidationError('敏感词汇') return value class BookSerializer(serializers.Serializer): id = serializers.IntegerField(required=False) title = serializers.CharField(max_length=32,)# 自定义的加这个参数 validators=[my_validate,] pub_time = serializers.DateField() category=serializers.CharField(source='get_category_display',read_only=True) #此处为多选时用 #read_only = True 正序查找 publisher=PublisherSerializer(read_only=True) #多对一 authors=AuthorSerializer(many=True,read_only=True) #多对多用 many=True #write_only =True 反序查找 要重新定义 post_category = serializers.IntegerField(write_only=True) publisher_id = serializers.IntegerField(write_only=True) author_list = serializers.ListField(write_only=True) #重写 create 方法 def create(self, validated_data): #validated_data 校验通过的数据 就是book_obj # 通过ORM操作给Book表增加数据 book_obj=Book.objects.create(title=validated_data['title'], pub_time=validated_data["pub_time"], category=validated_data["post_category"], publisher_id=validated_data["publisher_id"] ) book_obj.authors.add(*validated_data['author_list']) return book_obj
#重写update 方法def update(self, instance, validated_data): # instance 更新的book_obj 对象 # validated_data 校验通过的数据 # ORM做更新操作 对每个字段进行更新 instance.title=validated_data.get('title',instance.title) instance.pub_time = validated_data.get("pub_time", instance.pub_time) instance.category = validated_data.get("post_category", instance.category) instance.publisher_id = validated_data.get("publisher_id", instance.publisher_id) #此处是对多对多个字段 进行查询 if validated_data.get("author_list"): #set 因为是列表多个数据 instance.authors.set(validated_data["author_list"]) #编辑一定要更新 instance.save() return instance
# 对单个值进行校验 def validate_title(self,value): # value就是title的值 对value处理 if 'xxoo' not in value.lower(): raise serializers.ValidationError('少东西了') return value #对所有字段进行 校验 def validate(self, attrs): # attrs 字典有你传过来的所有的字段 if 'xxoo' in attrs['title'].lower() and attrs["post_category"] == 1: return attrs else: raise serializers.ValidationError('分类或标题不合符要求') 二.第二版本(用这个)用这个添加表里面的信息 直接用字段名
class BookSerializer(serializers.ModelSerializer): #对多选字段,一对多,多对多字段 进行重新定义 此处为序列化的时候显示 category_display=serializers.SerializerMethodField(read_only=True) publisher_info=serializers.SerializerMethodField(read_only=True) authors_info=serializers.SerializerMethodField(read_only=True) #多选查找 obj 就是序列化的每个Book对象 def get_category_display(self,obj): return obj.get_category_display() #一对多查找 def get_publisher_info(self,obj): #找到查找外键的对象 publisher_obj=obj.publisher #返回publisher表的内容 return {'id':publisher_obj.id,'title':publisher_obj.title} #多对多的查找 def get_authors_info(self,obj): #找到所有的对象 authors_obj=obj.authors.all() # 返回authors表的内容 推到式 return [{"id":i.id,'name':i.name}for i in authors_obj] class Meta: model=Book fields='__all__' # exclude=["id"] # 会让你这些所有的外键关系变成read_only = True 最多4层 不建议用 # depth = 1 #相当于extra_kwargs={"默认的字段名称":{自定义的参数配置信息}} #用在反序列化 给表字段添加参数 extra_kwargs={'publisher':{'write_only':True}, "authors": {"write_only": True}}
serializers 序列化器里面进行 校验等的更多相关文章
- drf序列化器serializers.SerializerMethodField()的用法
问题描述: 为什么DRF中有时候返回的json中图片是带域名的,有时候是不带域名的呢? 解析: 带域名的结果是在view中对模型类序列化的,DRF在序列化图片的时候 会检查上下文有没有request, ...
- DRF 序列化器-Serializer (2)
作用 1. 序列化,序列化器会把模型对象转换成字典,经过response以后变成json字符串 2. 完成数据校验功能 3. 反序列化,把客户端发送过来的数据,经过request以后变成字典,序列化器 ...
- Serializers 序列化组件
Serializers 序列化组件 为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转 ...
- 一: DRF web应用框架基础,及序列化器的使用
---恢复内容开始--- 一: web 应用模式(有两种) 1: 前后端不分离(前端从后端直接获取数据) 2: 前后端分离 二: api 接口 原因一: 为了在团队内部形成共识.防止个人习惯差异引起的 ...
- DRF中的序列化器
DRF中的序列化器详细应用 视图的功能:说白了就是接收前端请求,进行数据处理 (这里的处理包括:如果前端是GET请求,则构造查询集,将结果返回,这个过程为序列化:如果前端是POST请求,假如要对数 ...
- drf3 Serializers 序列化组件
为什么要用序列化组件 做前后端分离的项目,我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 给前端数据的时候都要转成json格式,那就需要对从数据库拿到的数据进行序列化. ...
- Serializers序列化组件
Django的序列化方法 .values 序列化结果 class BooksView(View): def get(self, request): book_list = Book.objects.v ...
- django rest_framework Serializers 序列化组件
为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿 ...
- 【转】Serializers 序列化组件
https://www.cnblogs.com/MayDayTime/p/9890582.html 为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON ...
随机推荐
- HDU 3376
http://acm.hdu.edu.cn/showproblem.php?pid=3376 题意:一个矩阵,每个点有价值,起点左上角终点右下角,每次只能走当前点的下一点或右一点,从起点走到终点,再从 ...
- 强大的dfs(用处1——拓扑排序【xdoj1025】,用处二——求强联通分量【ccf高速公路】)当然dfs用处多着咧
xdoj 1025 亮亮最近在玩一款叫做“梦想庄园”的经营游戏.在游戏中,你可以耕种,养羊甚至建造纺织厂. 如果你需要制造衣服,你首先得有布匹和毛线.布匹由棉花纺织而成:毛线由羊毛制成,而羊需要饲料才 ...
- LOJ2540. 「PKUWC2018」随机算法【概率期望DP+状压DP】
LINK 思路 首先在加入几个点之后所有的点都只有三种状态 一个是在独立集中,一个是和独立集联通,还有一个是没有被访问过 然后前两个状态是可以压缩起来的 因为我们只需要记录下当前独立集大小和是否被访问 ...
- 51Nod:1086背包问题 V2
1086 背包问题 V2 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 有N种物品,每种物品的数量为C1,C2......Cn.从中任选若干件放在容量为W的背包里 ...
- POJ1733 Parity game
题意 Language:Default Parity game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13833 Acc ...
- juc包下的集合类
import java.util.Iterator;import java.util.concurrent.CopyOnWriteArrayList; /** * 集合在多线程中同步的方式: * 1. ...
- Socket-Vs-WebSocket-TestTool
项目地址 : https://github.com/kelin-xycs/Socket-Vs-WebSocket-TestTool Socket-Vs-WebSocket-TestTool 一个用 ...
- EditorConfig知识点
.editorconfig 该文件定义项目的编码规范,编辑器的行为会与.editorconfig 文件中定义的一致,并且其优先级比编辑器自身的设置要高,这在多人合作开发项目时十分有用而且必要. 在哪里 ...
- 关于 BigDecimal 的小数位的入舍去操作
BigDecimal 保留小数 的 入舍操作, 6 中 策略 : RoundingMode 里面的 枚举 和 BigDecimal 的 常量 是等价的 UP(BigDecimal.R ...
- 设置zedgraph鼠标拖拽和局部放大属性(转帖)
说一下几个属性的意义和具体应用: (1)鼠标拖拽显示区域 PanModifierKeys ->> Gets or sets a value that determines which mo ...