DRF框架认证底层源码解析——简单易理解!

(前提:学过一点Django框架,更好理解)

一.从请求发送过来到执行认证的简单过程梳理

请求首先来到urls模块,而后根据 URL 映射找到 UserViewas_view() as_view()内部会执行两个命令(简单来说):

ini 复制代码
obj = UserView()  #实例化一个obj
obj.dispatch()  #调用对象的dispatch方法

as_view()方法源码在哪里呢?

来到view模块,从class UserView(APIView)里继承的APIView开始一步步跳转

APIView如下图所示 点进as_view(),找到一个叫view的方法,如下图所示

view 复制代码
def view(request, *args, **kwargs):
    self = cls(**initkwargs)
    self.setup(request, *args, **kwargs)
    if not hasattr(self, "request"):
        raise AttributeError(
            "%s instance has no 'request' attribute. Did you override "
            "setup() and forget to call super()?" % cls.__name__
        )
    return self.dispatch(request, *args, **kwargs)

view方法的self = cls(**initkwargs)>>>>实例化了obj

最后便调用了dispatch方法(这是接下来的核心!)

二.开始认证源码流程

看下图,简单清晰明了 不仅如此,dispatch里面还有关于权限和限流的方法,它就相当于一个入口。

相关推荐
野犬寒鸦20 小时前
从零起步学习MySQL || 第十六章:MySQL 分库分表的考量策略
java·服务器·数据库·后端·mysql
qq_2562470521 小时前
再见 Spec Kit?体验 Gemini CLI Conductor 带来的“全自动”开发流
后端
Moment21 小时前
如何一次性生成 60 种语气表达?RWKV 模型告诉你答案 ❗❗❗
前端·后端·aigc
想摆烂的不会研究的研究生21 小时前
每日八股——Redis(3)
数据库·redis·后端·缓存
悟能不能悟1 天前
springboot如何通过url地址获得这个地址的文件
java·spring boot·后端
问今域中1 天前
Spring Security + JWT
java·后端·spring
小杨同学491 天前
C 语言实战:超市水果结算系统(深度解析与优化)
后端·算法·设计
yangminlei1 天前
Spring Boot 响应式 WebFlux 从入门到精通
java·spring boot·后端
Apifox1 天前
Apifox CLI + Claude Skills:将接口自动化测试融入研发工作流
前端·后端·测试
调试人生的显微镜1 天前
使用Fiddler抓包工具获取微信公众号数据的完整教程
后端