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

相关推荐
Tony Bai3 小时前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
寻找奶酪的mouse4 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大4 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
毅炼4 小时前
Java 基础常见问题总结(4)
java·后端
想用offer打牌4 小时前
MCP (Model Context Protocol) 技术理解 - 第一篇
后端·aigc·mcp
千寻girling5 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
程序员清风5 小时前
北京回长沙了,简单谈谈感受!
java·后端·面试
何中应5 小时前
请求头设置没有生效
java·后端
NPE~5 小时前
自动化工具Drissonpage 保姆级教程(含xpath语法)
运维·后端·爬虫·自动化·网络爬虫·xpath·浏览器自动化
宋小黑5 小时前
JDK 6到25 全版本网盘合集 (Windows + Mac + Linux)
java·后端