Django REST framework(DRF)在处理不同请求方法时的完整流程

文章目录

  • 一、POST 请求创建对象的流程
  • 二、GET 请求获取对象列表的流程
  • 三、GET 请求获取单个对象的流程
  • 四、PUT/PATCH 请求更新对象的流程
  • 五、自定义方法的流程
    • 自定义 GET 方法
    • 自定义 POST 方法


一、POST 请求创建对象的流程

  1. 请求到达视图层

    • 方法调用: dispatch
    • 说明: DRF 的视图集接收到请求,dispatch 方法根据请求方法将请求分发到对应的处理方法(如 create)。
  2. 初始化请求

    • 方法调用: initial
    • 说明: 执行认证、权限检查、限流等操作。
  3. 调用视图的 create 方法

    • 方法调用: create
    • 说明: 根据请求,进入视图集的 create 方法处理创建逻辑。
  4. 获取序列化器并传入数据

    • 方法调用: get_serializer(data=request.data)
    • 说明: 实例化序列化器,将请求数据传入。
  5. 序列化器验证数据

    • 方法调用: is_valid(raise_exception=True)
    • 过程:
      • to_internal_value: 将输入数据转换为内部 Python 表示。
      • 字段验证: 对每个字段执行验证,如类型、格式等。
      • 对象级验证: 执行序列化器的 validate 方法,进行跨字段验证。
  6. 保存数据(调用序列化器的 create 方法)

    • 方法调用: save()
      • 内部调用: create(validated_data)
    • 说明: 数据验证通过后,调用 save 方法,进而调用序列化器的 create 方法,使用验证后的数据创建对象。
  7. 额外的操作(调用视图的 perform_create 方法)

    • 方法调用 perform_create()
    • 说明:在创建一个新的模型实例时执行额外的操作。
  8. 返回响应

    • 方法调用: Response(serializer.data, status=201)
    • 过程:
      • to_representation: 将对象数据序列化为可返回的格式。
    • 说明: 视图返回包含序列化数据的响应。

二、GET 请求获取对象列表的流程

  1. 请求到达视图层

    • 方法调用: dispatch
    • 说明: 请求被分发到视图的 list 方法。
  2. 初始化请求

    • 方法调用: initial
    • 说明: 执行认证、权限检查、限流等。
  3. 调用视图的 list 方法

    • 方法调用: list
    • 说明: 处理获取列表的逻辑。
  4. 获取查询集

    • 方法调用: get_queryset
    • 说明: 获取需要展示的对象集合。
  5. 过滤查询集

    • 方法调用: filter_queryset(queryset)
    • 说明: 根据过滤条件筛选数据。
  6. 分页(如果设置了分页器)

    • 方法调用: paginate_queryset(queryset)
    • 说明: 对查询集进行分页处理。
  7. 获取序列化器并序列化数据

    • 方法调用: get_serializer(instance=queryset, many=True)
    • 过程:
      • to_representation: 遍历查询集,对每个对象进行序列化。
    • 说明: 将对象数据转换为可返回的格式。
  8. 返回响应

    • 方法调用: Response(serializer.data)
    • 说明: 返回包含序列化数据的响应。

三、GET 请求获取单个对象的流程

  1. 请求到达视图层

    • 方法调用: dispatch
    • 说明: 请求被分发到视图的 retrieve 方法。
  2. 初始化请求

    • 方法调用: initial
    • 说明: 执行认证、权限检查、限流等。
  3. 调用视图的 retrieve 方法

    • 方法调用: retrieve
    • 说明: 处理获取对象详情的逻辑。
  4. 获取对象实例

    • 方法调用: get_object
      • 内部调用: get_queryset 和 filter_queryset
    • 说明: 根据 pk 或其他标识符获取单个对象。
  5. 获取序列化器并序列化数据

    • 方法调用: get_serializer(instance=object)
    • 过程:
      • to_representation: 将对象数据序列化。
    • 说明: 将对象转换为可返回的格式。
  6. 返回响应

    • 方法调用: Response(serializer.data)
    • 说明: 返回包含对象数据的响应。

四、PUT/PATCH 请求更新对象的流程

  1. 请求到达视图层

    • 方法调用: dispatch
  2. 初始化请求

    • 方法调用: initial
  3. 调用视图的 update 方法

    • 方法调用: update(PUT)或 partial_update(PATCH)
  4. 获取对象实例

    • 方法调用: get_object
  5. 获取序列化器并传入数据和实例

    • 方法调用: get_serializer(instance=object, data=request.data, partial=partial)
    • 说明: partial 参数决定是否允许部分更新。
  6. 序列化器验证数据

    • 方法调用: is_valid(raise_exception=True)
  7. 保存数据(调用序列化器的 update 方法)

    • 方法调用: save()
    • 内部调用: update(instance, validated_data)
  8. 返回响应

    • 方法调用: Response(serializer.data)

五、自定义方法的流程

自定义 GET 方法

  1. 请求到达视图层

    • 方法调用:dispatch
    • 说明:DRF 的视图接收到请求,dispatch 方法根据请求方法和路由信息,将请求分发到对应的处理方法。
  2. 初始化请求

    • 方法调用:initial
    • 说明:进行认证、权限检查和限流等操作。
  3. 调用自定义方法

    • 方法调用:custom_get
    • 说明:执行自定义的逻辑。由于这是一个 GET 请求,通常不会涉及数据的修改或序列化器的使用。
  4. 返回响应

    • 方法调用:Response
    • 说明:将处理结果封装在 Response 对象中,返回给客户端。

注意:在这个过程中,不会涉及序列化器的方法调用,除非您在自定义方法中主动使用序列化器。

自定义 POST 方法

  1. 请求到达视图层

    • 方法调用:dispatch
  2. 初始化请求

    • 方法调用:initial
  3. 调用自定义方法

    • 方法调用:custom_post
  4. 获取序列化器并传入数据

    • 方法调用:get_serializer(data=request.data)
    • 说明:实例化序列化器,用于数据验证和保存。
  5. 序列化器验证数据

    • 方法调用:is_valid(raise_exception=True)
    • 过程:
      • to_internal_value:将输入的数据转换为内部 Python 数据类型。
      • 字段验证:验证各个字段的有效性。
      • validate 方法:执行对象级别的验证。
  6. 保存数据

    • 方法调用:perform_create(serializer)

      • 内部调用:serializer.save()
    • 说明:调用序列化器的 save 方法,进而调用 create 方法,将数据保存到数据库。

  7. 序列化器保存数据

    • 方法调用:create(validated_data)
    • 说明:使用经过验证的数据创建新的对象实例。
  8. 返回响应

    • 方法调用:Response(serializer.data, status=201)
    • 过程:
      • to_representation:将创建的对象实例序列化为可 JSON 化的数据。
    • 说明:将创建的对象数据返回给客户端。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/940221.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

list的常用操作

list的介绍 list是序列容器,它允许在常数范围O(1)进行插入和删除在这段序列的任意位置,并且可以双向遍历 它是弥补vector容器的缺点,与vector有互补的韵味, 这里我们可以将其进行与vector进行对比 vect…

C# opencvsharp 流程化-脚本化-(2)ROI

ROI ROI也是经常需要使用的方法。特别是在图像编辑中。ROI又称感兴趣的区域,但是图像是矩阵是矩形的,感兴趣的是乱八七糟的,所以还有一个Mask需要了解一下的。 public class RoiStep : IImageProcessingStep{public ImageProcessingStepType…

极狐GitLab 正式发布安全补丁版本 17.6.2、17.5.4、 17.4.6

本分分享极狐GitLab 补丁版本 17.6.2, 17.5.4, 17.4.6 的详细内容。这几个版本包含重要的缺陷和安全修复代码,我们强烈建议所有私有化部署用户应该立即升级到上述的某一个版本。对于极狐GitLab SaaS,技术团队已经进行了升级,无需用户采取任何…

在window环境下安装openssl生成钥私、证书和签名,nodejs利用express实现ssl的https访问和测试

在生成我们自己的 SSL 证书之前,让我们创建一个简单的 Express应用程序。 要创建一个新的 Express 项目,让我们创建一个名为node-ssl -server 的目录,用终端cmd中进入node-ssl-server目录。 cd node-ssl-server 然后初始化一个新的 npm 项目…

CTFHub ssrf

第一关(内网访问) 尝试访问位于127.0.0.1的flag.php吧 第二关(伪协议读取文件) 尝试去读取一下Web目录下的flag.php吧 1.首先尝试http://127.0.0.1/flag.php 2.查看页面源代码 3.根据提示输入file:///var/www/html/flag.php 4.查看页面源代码 第三关&…

vue3+vite一个IP对站点名称的前端curd更新-会议系统优化

vue3-tailwind-todo https://github.com/kgrg/vue3-tailwind-todo 基于这个项目,把ip到sta的映射做了前端管理. 核心代码是存储和获得的接口,需要flask提供. def redis2ipdic():global ipdicipdic.clear()tmdiccl.hgetall(IPDIC_KEY)for k in tmdic.keys():ipdic[k.decode() …

idea无法识别文件,如何把floder文件恢复成model

前景: 昨天,我在之前的A1214模块包下新增了一个demo类,然后又新建了一个A1216模块,写了算法题,后面打算用git提交,发现之前的A1214模块下的demo类和新建的模块源文件都已经被追踪了,都是绿色的&…

如何调大unity软件的字体

一、解决的问题: unity软件的字体太小,怎么调大点?二、解决方法: 1.操作步骤: 打开Unity编辑器> Edit>preferences> UI Scaling>Use custom scaling value(取消勾选“使用默认桌面设置”&…

冯诺依曼架构与哈佛架构的对比与应用

冯诺依曼架构(Von Neumann Architecture),也称为 冯诺依曼模型,是由著名数学家和计算机科学家约翰冯诺依曼(John von Neumann)在1945年提出的。冯诺依曼架构为现代计算机奠定了基础,几乎所有现代…

实操给桌面机器人加上超拟人音色

前面我们讲了怎么用CSK6大模型开发板做一个桌面机器人充当AI语音助理,近期上线超拟人方案,不仅大模型语音最快可以1秒内回复,还可以让我们的桌面机器人使用超拟人音色、具备声纹识别等能力,本文以csk6大模型开发板为例实操怎么把超…

Fiddle突然抓不到虚拟机的地址

Fiddle不抓虚拟机的地址了 查看是否更换了ip地址,我是因为换了网络 更换正确的ip地址

Flutter组件————AppBar

AppBar 是 Flutter 中用于创建应用程序顶部栏的组件,它遵循 Material Design 规范。 参数: 参数名称类型描述titleWidget设置 AppBar 中的标题文本或自定义标题小部件。automaticallyImplyLeadingbool决定是否自动添加返回按钮(如果页面不是…

【Java基础面试题025】什么是Java的Integer缓存池?

回答重点 Java的Integer缓存池(Integer Cache)是为了提升性能和节省内存。根据实践发现大部分的数据操作都集中在值比较小的范围,因此缓存这些对象可以减少内存分配和垃圾回收的负担,提升性能 在 -128到127范围内的Integer对象会…

【JavaEE初阶】线程 和 thread

本节⽬标 认识多线程 掌握多线程程序的编写 掌握多线程的状态 一. 认识线程(Thread) 1概念 1) 线程是什么 ⼀个线程就是⼀个 "执⾏流". 每个线程之间都可以按照顺序执⾏⾃⼰的代码. 多个线程之间 "同时" 执⾏着多份代码. 还…

js 面试题

目录 Promise调用 Set 递归 有一个楼梯,每次可以走1个台阶或2个台阶,总共有几种走法 计算1~100之和 数组 求数组中最大值 迭代(遍历)数组 扁平化数组 使用flat toString() 手写递归 使用while 数组倒序 对象 对象属性遍历 扁平化对象 Promise调用 …

在租用服务器上配置环境

使用的是并行计算云,现在有活动,可以用到明年3月多。50元入会,有500元的卷。 注册完会员后,按照图里说的领卷即可,卷会发送到邮箱里,按照要求兑换就好。下面是具体使用流程。 可以在不开机的情况下&#…

run postinstall error, please remove node_modules before retry!

下载 node_modules 报错:run postinstall error, please remove node_modules before retry! 原因:node 版本出现错误,我的项目之前是在 12 下运行的。解决方法: 先卸载node_modules清除缓存将node版本切换到12重新下载即可

基于蓝牙通信的手机遥控智能灯(论文+源码)

1.系统设计 灯具作为人们日常生活的照明工具为人们生活提供光亮,本次基于蓝牙通信的手机遥控智能灯设计功能如下: (1)用户可以通过蓝牙通信模块的作用下,在手机端遥控切换智能灯不同的工作模式; &#x…

IDEA搭建SpringBoot,MyBatis,Mysql工程项目

目录 一、前言 二、项目结构 三、初始化项目 四、SpringBoot项目集成Mybatis编写接口 五、代码仓库 一、前言 构建一个基于Spring Boot框架的现代化Web应用程序,以满足[公司/组织名称]对于[业务需求描述]的需求。通过利用Spring Boot简化企业级应用开发的优势&…

[HNCTF 2022 Week1]你想学密码吗?

下载附件用记事本打开 把这些代码放在pytho中 # encode utf-8 # python3 # pycryptodemo 3.12.0import Crypto.PublicKey as pk from hashlib import md5 from functools import reducea sum([len(str(i)) for i in pk.__dict__]) funcs list(pk.__dict__.keys()) b reduc…