您现在的位置: 首页 环境保护 > > 正文
每日快报!drf——Request源码分析、序列化组件、序列化类的使用(字段类和参数)、反序列化校验和保存
发布时间:2023-05-17 20:31:59 来源:博客园


(资料图片)

1.Request类源码分析
# APIView+Response写个接口# 总结:1.新的request有个data属性,以后只要是在请求body体中的数据,无论什么编码格式,无论什么请求方式    2.取文件还是从:request.FILES    3.取其他属性,跟之前完全一样 request.method ....    原理:新的request重写了__getattr__,通过反射获取老的request中的属性    4.request.GET 现在可以使用request.query_params    @property        def query_params(self):            return self._request.GET        # 补充魔法方法之__getattr__,对象.属性 当属性不存在是,会触发类中__getattr__的执行# get请求能不能在body体中带数据能!
2.序列化组件介绍
1. 序列化,序列化器会把模型对象(queryset,单个对象)转换成字典,经过response以后变成json字符串2. 反序列化,把客户端发送过来的数据,经过request.data以后变成字典,序列化器可以把字典转成模型3. 反序列化,完成数据校验功能
3.序列化类的基本使用
# 1 创建book表模型# 2 写查询所有图书的接口:APIVie+序列化类+Response
3.1查询所有和查询单条views.py中
class BookView(APIView):    def get(self,request):        book_list = Book.objects.all()        # 使用序列化类,完成序列化 两个很重要参数:instance:(实例,对象) data:数据        # 如果是多条many=True 如果是queryset对象 就要写        # 如果是单个对象many=False 或者可以不写 默认是False        serializer = BookSerializer(instance=book_list,many=True)        # serializer.data 把queryset对象转成列表套字典 ReturnList        return Response({"code":100,"msg":"成功","data":serializer.data})class BookDetailView(APIView):    def get(self,request,pk):        book = Book.objects.get(pk=pk)        serializer = BookSerializer(instance=book,many=False)        return Response({"code":100,"msg":"成功","data":serializer.data})
urls.py中
urlpatterns = [    path("books/", views.BookView.as_view()),    path("books//", views.BookDetailView.as_view()),]
序列化类
from rest_framework import serializersclass BookSerializer(serializers.Serializer):    # 要序列化的字段    id = serializers.IntegerField()    name = serializers.CharField()    price = serializers.IntegerField()
总结
# 序列化类的使用1.写一个类 继承serializers.Serializer2.在类中写字段,要序列化的字段3.在视图类中使用:(多条,单条)    serializer = BookSerializer(instance=book_list, many=True)    serializer = BookSerializer(instance=book)
4.常用字段类和参数(了解)4.1常用字段类
字段字段构造方式
BooleanFieldBooleanField()
NullBooleanFieldNullBooleanField()
CharFieldCharField(max_length=None, min_length=None, allow_blank=False, trim_whitespace=True)
EmailFieldEmailField(max_length=None, min_length=None, allow_blank=False)
RegexFieldRegexField(regex, max_length=None, min_length=None, allow_blank=False)
SlugFieldSlugField(maxlength=50, min_length=None, allow_blank=False) 正则字段,验证正则模式 [a-zA-Z0-9-]+
URLFieldURLField(max_length=200, min_length=None, allow_blank=False)
UUIDFieldUUIDField(format=’hex_verbose’) format: 1) "hex_verbose""5ce0e9a5-5ffa-654b-cee0-1238041fb31a"2) "hex""5ce0e9a55ffa654bcee01238041fb31a"3)"int"- 如: "123456789012312313134124512351145145114"4)"urn"如: "urn:uuid:5ce0e9a5-5ffa-654b-cee0-1238041fb31a"
IPAddressFieldIPAddressField(protocol=’both’, unpack_ipv4=False, **options)
IntegerFieldIntegerField(max_value=None, min_value=None)
FloatFieldFloatField(max_value=None, min_value=None)
DecimalFieldDecimalField(max_digits, decimal_places, coerce_to_string=None, max_value=None, min_value=None) max_digits: 最多位数 decimal_palces: 小数点位置
DateTimeFieldDateTimeField(format=api_settings.DATETIME_FORMAT, input_formats=None)
DateFieldDateField(format=api_settings.DATE_FORMAT, input_formats=None)
TimeFieldTimeField(format=api_settings.TIME_FORMAT, input_formats=None)
DurationFieldDurationField()
ChoiceFieldChoiceField(choices) choices与Django的用法相同
MultipleChoiceFieldMultipleChoiceField(choices)
FileFieldFileField(max_length=None, allow_empty_file=False, use_url=UPLOADED_FILES_USE_URL)
ImageFieldImageField(max_length=None, allow_empty_file=False, use_url=UPLOADED_FILES_USE_URL)
ListFieldListField(child=, min_length=None, max_length=None)
DictFieldDictField(child=)
# IntegerField      CharField   DateTimeField  DecimalField# ListField和DictField---》比较重要,但是后面以案例形式讲
4.2字段参数(校验数据来用的)

选项参数:

参数名称作用
max_length最大长度
min_lenght最小长度
allow_blank是否允许为空
trim_whitespace是否截断空白字符
max_value最小值
min_value最大值

通用参数:

参数名称说明
read_only表明该字段仅用于序列化输出,默认False
write_only表明该字段仅用于反序列化输入,默认False
required表明该字段在反序列化时必须输入,默认True
default反序列化时使用的默认值
allow_null表明该字段是否允许传入None,默认False
validators该字段使用的验证器
error_messages包含错误编号与错误信息的字典
label用于HTML展示API页面时,显示的字段名称
help_text用于HTML展示API页面时,显示的字段帮助提示信息
# read_only   write_only   很重要,后面以案例讲
5.反序列化之校验
# 反序列化,有三层校验1.字段自己写的(写的字段参数:required max_length)    2.局部钩子:写在序列化类中的方法,方法名必须是 validate_字段名        def validate_name(self,name):            if "sb" in name:                # 不合法 抛异常                raise ValidationError("书名中不能包含sb")            else:                return name     3.全局钩子:写在序列化类中的方法 方法名必须是 validate        def validate(self,attrs):            price = attrs.get("price")            name = attrs.get("name")            if name == price:                raise VilidationError("价格不能等于书名")            else:                return attrs    # 只有三层都通过 在视图类中:    ser.is_valid(): 才是True,才能保存
6.反序列化之保存
# 新增接口:序列化类的对象,实例化的时候:ser = BookSerializer(data=request.data)    数据校验过后--->调用 序列化类.save() ---> 但是要在序列化类中重写 create方法    def create(self,validated_data):            # validated_data校验过后的数据,字典            book=Book.objects.create(**validated_data)            return book        # 修改接口序列化类的对象 实例化的时候:ser = BookSerializer(instance=book,data=request.data)    数据校验过后----》调用 序列化类.save()--->但是要在序列化类中重写  update方法    def update(self,book,validated_data):            for item in validated_data: # {"name":"jinping","price":55}                setattr(book,item,validated_data[item])                # 等同于下面                # setattr(book,"name","jinping")                # setattr(book,"price",55)                # 等同于                # book.name = validated_data.get("name")                # book.price = validated_data.get("price")            book.save()            # 一定不要忘了            return book        # 研究了一个问题在视图类中,无论是保存还是修改,都是调用序列化类.save(),底层实现是根据instance做一个判断 看是否有instance参数传入
7.增删改查5个接口表模型
点击查看代码
from django.db import modelsclass Book(models.Model):    name = models.CharField(max_length=32)    price = models.BigIntegerField()
路由
点击查看代码
urlpatterns = [    path("books/", views.BookView.as_view()),    path("books//", views.BookDetailView.as_view()),]
视图
点击查看代码
from .models import Bookfrom .serialiazer import BookSerialiazerclass BookView(APIView):    # 查所有    def get(self,request):        book_list = Book.objects.all()        # 使用序列化类,完成序列化 两个很重要的参数:instance(实例,对象) data:数据        # 如果是多条数据 many=True 如果是queryset对象就要写        # 如果是单个对象 many=False,默认是False        serializer = BookSerializer(instance=book_list,many=True)        # serializer.data # 把queryset对象,转成列表套字典 ReturnList        return Response({"code":100,"msg":"成功","data":serializer.data})        # 新增    def post(self,request):        # 前端会传入数据到request.data ---> 把这个数据保存到数据库中        # 借助于序列化类 完成校验和反序列化        # data前端传入的数据 {"name":"三国演义","price":88}        ser  = BookSerializer(data=request.data)        # 校验数据        if ser.is_valid():  # 三层:字段自己的校验-->局部钩子校验-->全局钩子校验            # 校验通过 保存            print(ser.validated_data)  # validated_data:校验过后的数据            # 如果没有save,如何保存,自己做            # Book.objects.create(**validated_data)            ser.save()  # 会保存,但是会报错 因为它不知道你要保存到哪个表中            return Response({"code": 100, "msg": "新增成功"})        else:            print(ser.errors)  # 校验失败的错误            return Response({"code": 101, "msg": "新增失败", "errors": ser.errors})        class BookDetailView(APIView):    # 查找单条数据    def get(self,request,pk):        book = Book.objects.all().get(pk=pk)        serializer = BookSerializer(instance=book)        return Response({"code": 100, "msg": "成功", "data": serializer.data})        def put(self,request,pk):        # 修改单条数据        book = Book.objects.get(pk=pk)        ser = BookSerializer(instance=book,data=request.data)        if ser.is_valid():            ser.save()  # 也会报错 重写update            return Response({"code": 100, "msg": "修改成功"})        else:            return Response({"code": 101, "msg": "修改失败", "errors": ser.errors})
序列化类
点击查看代码
# from rest_framework.serializers import Serializerfrom rest_framework import serializersfrom rest_framework.exceptions import ValidationErrorfrom .models import Bookclass BookSerializer(serializers.Serializer):    # 要序列化的字段    id = serializer.IntegerField(required=False)  # 前端传入数据,可以不填这个字段    name = serializers.CharField(allow_blank=True,required=False,max_length=8,min_length=3,error_messages={"max_length":"太长了"})  # allow_blank:这个字段传了,value值可以为空    price = serializers.IntegerField(max_value=100, min_value=10,error_messages={"max_value": "必须小于100"})    """局部钩子:给某个字段做个校验"""# 书名中不能包含sb# validate_字段名def validate_name(self,name):    if "sb" in name:        # 不合法,抛异常        raise ValidationError("书名中不能包含sb")    else:        return name  def validate_price(self,item):    if item == 88:        raise ValidationError("价格不能等于88")    else:        return item    """全局钩子"""# 价格和书名不能一样  validatedef validate(self,attrs):    price = attrs.get("price")    name = attrs.get("name")    if name == price:        raise ValidationError("价格不能等于书名")    else:        return attrs    def create(self,validated_data):    # validated_data校验过后的数据 字典    book = Book.objects.create(**validated_data)    return bookdef update(self,instance,validated_data):    # instance ---> 要修改的对象    # validated_data ---> 前端传入 并且校验过后的数据    for key in validated_data:        setattr(instance,item,validated_data[key])        """        等同于下面        setattr(instance,"name","jinping")        setattr(instance,"price",55)        等同于下面        instance.name = validated_data.get("name")        instance.price = validated_data.get("price")        """    instance.save() # 一定不要忘记save()    return instance    

标签:

新兴食品现身市场 “植物肉”产品能否“俘获”消费者的胃?

最近一段时间,部分超市和电商平台售卖的植物肉纷纷推出促销优惠活动,销量看涨。不过也有消费者表示,...

绍兴招才引智云对话活动举行 诚邀天下英才“会盟”绍兴

懂人才是大学问,聚人才是大本事,用人才是大智慧。近年来,绍兴市大力实施人才强市战略,持续深化人才...

江苏省自然资源厅出台指导意见 推进老旧小区改造工作

省自然资源厅近日出台《关于大力推进城镇老旧小区改造工作的指导意见》,针对城镇老旧小区改造中规划和...

2021年中国心血管健康指数排名:江苏位列前五

进行了排名,江苏位列前五。北京、上海、江苏等地居民心血管更健康这项发表在《中国疾病预防控制中心周...

科研人员揭示5种豆科植物的核型数据及亲缘关系

近日,四川农业大学林学院副教授罗小梅团队在遗传学领域期刊《基因》(Genes),在线发表了题为《基于5S ...

“烟火气”十足的“江苏味道” 河西CBD顶流商圈开街迎客

开街啦!5月18日上午,在河西CBD金融城融媒路上,2022江苏省新能源汽车&信息消费创新产品推广系列活动启...

首个锌金属的伴侣蛋白诞生 有助于解决缺锌公共卫生问题

据17日发表在《细胞》与《细胞报告》杂志上的两篇论文,美国研究人员发现了第一个锌金属的伴侣蛋白,并...

科学家首次揭示糖尿病卵母细胞起源 有助于减少生育缺陷

5月19日,记者从浙江大学获悉,浙大医学院附属妇产科医院黄荷凤院士团队与中国科学院徐国良院士团队合作...

前4月河北省电信网络诈骗案件发案数连续4个月同比下降

记者从省政府新闻办5月18日举行的河北省打击治理电信网络诈骗犯罪工作新闻发布会上获悉,今年1至4月,全...

重庆:到2025年25个重点领域企业能效全部达到基准水平

3月18日,重庆日报记者从市发展改革委获悉,日前,市发展改革委、市经济信息委、市生态环境局、市市场监...

重磅!2021“发现重庆之美”获奖名单揭晓

3月19日,2021发现重庆之美颁奖典礼在线上举行,最美城市管理人、最美坡坎崖、最美街头绿地、垃圾分类时...

去年重庆回收废弃农膜1.4万吨 农膜回收率达89.31%

3月16日,市五届人大常委会第六十九次主任会议听取了市政府关于《重庆市人大常委会对市人民政府农业面源...

申报分两批!今年国家级博士后科研工作站新设站工作启动

3月19日,重庆日报记者从市人力社保局获悉,为推动产学研深度融合,加强博士后工作平台建设,我市将开展...

浙江鄞州:“水、电、气、数”通办专窗实现城乡公共服务均等化

近日,在宁波市鄞州区邱隘镇公共事务服务中心,66岁的邱隘镇沈家新村居民邱秀月在一个窗口相继办理了不...

打开“浙里办” 浙江1000家农贸市场农产品可线上比价

今天哪个菜场的五花肉最便宜?食品安全抽检结果怎么样?这些问题,浙江居民只需打开浙里办APP上的浙里市场...

浙江鉴湖国家湿地公园规划发布 打造乡村数字旅游

19日上午,鉴湖国家湿地公园规划发布暨东鉴湖农旅观光体验启动仪式在绍兴市越城区陶堰街道举行。当天,...

总投资超10亿元!6个石化装备运维项目在岱山签约

日前,总投资超10亿元的6个石化装备运维项目在岱山经济开发区集中签约。此次签约的项目占地106亩,规划...

如何避免成为“买而不做”的“装备党”祝 杰

自恋是人的天性,人们总是希望自己是更好的,那么自己拥有的事物,也就相应地被自我赋予了更高的价值,...

山西临汾:率先在全省建起农村集体经济开发区

3月17日,临汾市农村集体经济发展(集团)有限公司在临汾经济开发区揭牌。以此为标志,临汾率先在全省建起...

一线工作近22年的缉毒警:我知道坏的是毒品不是人性

  “影子”般的缉毒警:一线工作22年,我知道坏的是毒品不是人性  如果我不继续干,别人也要干,缉...

广东肇庆“毒驾连撞5车致1死”肇事司机被批捕

  1月5日14时30分许,广东肇庆市端州区一男子赵某毒驾连撞5车,致一人死亡。  1月10日,澎湃新闻(ww...

江西最大文物倒卖案宣判:倒卖国家二级文物 9人获刑

  中新网南昌1月10日电 (冷峥嵘 张一怡)江西省共青城市人民法院10日发布消息称,近日,该院依法审结...

青海保障门源地震后生活必需品应急物资

  中新网西宁1月10日电 (记者 孙睿)记者10日从青海省商务厅获悉,青海海北州门源县6 9级地震灾害发...

广西东兴口岸恢复通关 入境需网上预约

  中新社防城港1月10日电 (翟李强)自2022年1月10日零时起,广西东兴口岸和边民互市贸易区恢复人员、...

呼和浩特:寒假期间有条件的学校要开展校内托管服务

  中新网呼和浩特1月10日电 (记者 张林虎)10日,记者从呼和浩特市教育局获悉,在暑假校内托管试点的...

“中国最后一个原始部落”翁丁老寨火灾原因公布

北京市十五届人大五次会议胜利闭幕

天津市委市政府致全市父老乡亲的慰问信:我们一定能够打赢

天津米面油存量由20天提高至30天 超市菜市场进货量翻倍

兰州名师话“美育”:“尚乐立人”分层培优 以“美”润教

子夜直击,天津寒天战“疫”

重庆姐弟被生父扔下坠亡案上诉期结束 一审法院暂未收到两被告人上诉状

天津:划定封控区 全市开展全员核酸检测

江歌母亲江秋莲:尊重法院判决,法律认定在我意料之中

中国边疆“北方第一所”:9名民警守护“生命禁区”

辟谣!网传“封控区管控区相继解封”通知并非西安

河南安阳9日12时至24时新增11例本土确诊病例

老人5折环卫工8折生活困难免费 这家面馆背后有个暖心事

铁路公安以110幅优秀书画作品庆祝人民警察节

本周中东部冷空气频繁 东北等地有降雪

河南新增本土确诊病例60例

“打拐”民警眼里的百态人生:见证一份份不愿放弃的爱

迎腊八北京晴天上线 阵风6至7级体感冻人

多省份倡议春节“非必要不离开”,这地补贴1000元

伪造国家机关证件典型案例发布 有力打击制假贩假行为

15年照顾170多个新生儿 金牌月嫂“漂”到海外去看娃

江歌母亲江秋莲诉刘鑫案一审将于今日宣判

河南省安阳市两地划为高风险地区 一地划为中风险地区

员工迟到一次罚一千引争议 单位惩戒员工法律边界何在?

以体育人 秀出“青年范儿”

保安、厨师曾被竞业限制 企业滥用竞业限制让员工很苦恼

反诈老陈破圈:人民群众在哪 就把反诈宣传开展到哪

一所中职学校的育人实践

各地严惩恶意欠薪 保障农民工及时拿到工资

中学生成剧本杀行业潜在消费人群 多方助推行业“净化”

“这就是我最好的选择”

对餐饮浪费说“不”(百姓关注)

校园“直通车” 服务“零距离”

琉璃河遗址 两段铭文共证北京三千年建城史

千元修复个人征信报告?银行:“征信修复”都是骗局

琉璃河遗址 两段铭文共证北京三千年建城史

北京公交将开展无人驾驶道路测试

河南郑州调整五地为中风险区域 公路入郑需核酸检测阴性证明

“共享法庭”让金融消费者畅享“智慧司法”便利

《传奇2》网游著作权纠纷案峰回路转 最高法五份裁决四份改判一份发回重审

三代警察:从未放弃的28年

“胡叔叔”的寻亲工作室

天津津南本轮本土疫情第3—20例阳性感染者活动轨迹公布

“团圆”行动刑侦专家吕游 每一个案例都有单独的技术方案

河南“战疫”直面五重考验

开考古书店日均两三个顾客 流量时代她决心仍是只卖书

冬奥开幕在即 “双减”催热冰雪课堂

“不得以任何借口拒收患者”彰显生命至上

天津多站进京车票暂停发售

冷空气来袭广州气温骤降 广东多地发布寒冷预警

x 广告
x 广告

Copyright ©  2015-2022 大西洋自然网版权所有  备案号:沪ICP备2020036824号-2   联系邮箱: 562 66 29@qq.com