gpt4 book ai didi

Django restframework 源码分析之认证详解

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Django restframework 源码分析之认证详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

前言 。

最近学习了 django 的一个 restframework 框架,对于里面的执行流程产生了兴趣,经过昨天一晚上初步搞清楚了执行流程(部分方法还不太清楚),于是想详细的总结一下当来一个请求时,在该框架里面是如何执行的?

启动项目时 。

昨天在调试django时,发现在 apiview 中打的断点没有断下来,而是打在 view 中的断点断下来了,调试了很多次,最后发现,在 django 项目启动时,会首先加载 urls 中的文件,执行 views 中类的 as_view方法,其实是继承自 apiview 的,apiview 继承自 django 原生 view 的as_view 方法.

里面一个参数叫 pattern_name,对应的值是admin:auth_group_change,如下图所示:

Django restframework 源码分析之认证详解

目前还不清楚这里面的具体流程是什么,但是并不妨碍阅读之后的源码,在这只要清楚一点,在 django 项目启动时,路由所对应的cbv里面的相关方法的内存地址已经获取到。这样做的好处就是提高效率,坏处可能有一点点,会提升性能的消耗.

具体路由和逻辑代码 。

在这里假设来一个 get 请求,urls 和 views里面的代码如下:

?
1
2
3
# urls.py
 
url(r '^book/(?p<id>\d+)/' , views.book.as_view()),
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# views.py
class book(apiview):
 
   def dispatch( self , request, * args, * * kwargs):
     return super ().dispatch(request, * args, * * kwargs)
 
   def get( self , request, id ):
 
     response = { 'status' : 100 , 'msg' : none}
 
     book = models.book.objects. filter (pk = id ).first()
     book_ser = bookserib(book, many = false)
     print ( 'book_ser.data' , book_ser.data)
     response[ 'books' ] = book_ser.data
     response[ 'msg' ] = '获取图书成功'
     print ( 'response' , response)
     return response(response)

urls 里面就是一个典型的 cbv 的路由配置,在 views 中一个是路由分发方法,一个是获取单本图书信息(通过 id).

as_view 具体执行流程 。

在项目启动时,相应的函数内存地址已经获取到,那么具体是怎么获取到的呢?

在上面的代码中可以看到 book 类是继承自 apiview 类的,所以在路由配置里面执行的 as_view 方法如果 book 类没有重写,那么执行的就是按照 mro 列表顺序查找到的第一个方法,在这里执行的是 apiview 类中的 as_view 方法.

查看该源码如下:

Django restframework 源码分析之认证详解

apiview 类的父类是 view 类,查看该类的 as_view 方法,源码如下:

Django restframework 源码分析之认证详解

具体 as_view 就是将 view 函数的内存地址返回,以便请求来时直接调用.

而 initkwargs 这个参数应该是由 django 内部传的一些参数,如下所示:

Django restframework 源码分析之认证详解

请求到来时 。

因为经过 django 先执行了 as_view 返回 view 的内存地址,所以会直接执行 view 函数,如下:

Django restframework 源码分析之认证详解

在这里该 self 由于是 继承自 apiview 类的 book 类的对象,所以 dispatch 方法首先去自身找,之后去父类找,在 apiview 类中找到 dispatch 方法,源码如下:

Django restframework 源码分析之认证详解

initialize_request方法:

源码如下:

Django restframework 源码分析之认证详解

在实例化 request 对象时, authenticators 参数需要在认证时使用,所以先把这个参数的值找出来。步骤如下:

调用 self.get_authenticators 。

Django restframework 源码分析之认证详解

找到 self.authentication_classes 。

Django restframework 源码分析之认证详解

找到 api_settings,才能找到default_authentication_classes 。

Django restframework 源码分析之认证详解

default和import_strings参数 。

default参数 。

Django restframework 源码分析之认证详解

import_strings参数 。

Django restframework 源码分析之认证详解

实例化 apisettings 对象 。

Django restframework 源码分析之认证详解

通过__getattr__方法获取值 。

Django restframework 源码分析之认证详解

执行perform_import方法 。

Django restframework 源码分析之认证详解

执行import_from_string 。

Django restframework 源码分析之认证详解

执行import_module 。

Django restframework 源码分析之认证详解

执行_bootstrap._gcd_import 。

Django restframework 源码分析之认证详解

执行_sanity_check 。

Django restframework 源码分析之认证详解

_sanity_check返回,执行_find_and_load方法 。

Django restframework 源码分析之认证详解

所以通过__getattr__的到的是一个列表,里面是两个类,分别是[rest_framework_authentication_sessionauthentication, rest_framework_authentication_basicauthentication] 。

到这里,initialize_request方法执行结束,得到一个经过 request 类实例化的 request 对象,该对象里面含有原生 request 对象,可以通过 request._request 取到.

initial 方法:

源码如下:

Django restframework 源码分析之认证详解

这里传入的 request 参数是经过 request 封装后的参数 。

执行get_format_suffix 。

Django restframework 源码分析之认证详解

执行完这个方法, self_format_kwarg = none , 。

执行perform_content_negotiation 。

Django restframework 源码分析之认证详解

执行self.get_renders 。

Django restframework 源码分析之认证详解

执行self.get_content_negotiator 。

Django restframework 源码分析之认证详解

执行 conneg.select_renderer方法 。

Django restframework 源码分析之认证详解

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:http://www.cnblogs.com/zuanzuan/p/10412165.html 。

最后此篇关于Django restframework 源码分析之认证详解的文章就讲到这里了,如果你想了解更多关于Django restframework 源码分析之认证详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com