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里面还有关于权限和限流的方法,它就相当于一个入口。

相关推荐
sheji34161 小时前
【开题答辩全过程】以 基于SpringBoot的疗养院管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
短剑重铸之日1 小时前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
码界奇点2 小时前
基于Flask与OpenSSL的自签证书管理系统设计与实现
后端·python·flask·毕业设计·飞书·源代码管理
代码匠心3 小时前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
分享牛3 小时前
LangChain4j从入门到精通-11-结构化输出
后端·python·flask
知识即是力量ol5 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传
闻哥5 小时前
深入理解 Spring @Conditional 注解:原理与实战
java·jvm·后端·python·spring
qq_256247056 小时前
Google 账号防封全攻略:从避坑、保号到申诉解封
后端
MX_93596 小时前
使用Spring的BeanFactoryPostProcessor扩展点完成自定义注解扫描
java·后端·spring
弹简特6 小时前
【JavaEE05-后端部分】使用idea社区版从零开始创建第一个 SpringBoot 程序
java·spring boot·后端