久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Django DRF APIView源碼運行流程詳解

瀏覽:115日期:2024-09-23 14:28:09

首先寫一個簡單的drf接口

from rest_framework.views import APIViewfrom rest_framework.response import Response# 基于drf寫接口,cbvclass DrfTest(APIView): def get(self, request,*args,**kwargs): print(type(request._request)) print(type(request)) print(request.POST) print(request.GET) response = {’status’:100,’errors’:None} response[’users’] = user_list return Response(response) def post(self,request,*args,**kwargs): name = request.data.get(’name’) print(name) return HttpResponse(’ok’)

url(r’DrfTest/’,views.DrfTest.as_view()),

通過路由配置 點入查看源碼,首先進入到APIView的as_view的方法中:

Django DRF APIView源碼運行流程詳解

Django DRF APIView源碼運行流程詳解

查找dispatch方法:

Django DRF APIView源碼運行流程詳解

如果自己所定義的class DrfTest(APIView)沒有手擼dispatch的情況下,下一步,找到APIView里的dispatch方法:

Django DRF APIView源碼運行流程詳解

當中有一個self.initial(request, *args, **kwargs)方法:

Django DRF APIView源碼運行流程詳解

至此,簡單分析如上:回到最開始定義類的過程:

Django DRF APIView源碼運行流程詳解

流程總結

請求來了,執行了View類中as_view的view()方法,本質上執行了self.dispatch方法 按順序查找dispatch方法(自己類中,父類中,父父類中...) 在APIView中的dispatch方法中先把原來request封裝進去,變成新的request對象 接下來又執行了三個組件,分別是認證,權限和頻率 如果三個中有一個不滿足,則不繼續執行 再走分發方法,最后返回response出去 即在請求進入視圖函數前加了一些東西,重寫了dispatch方法

dispatch方法:

傳入的request是原生的request對象 這個request已經不是原生的request了,但是它內部有個原生的request對象 request = self.initialize_request(request, *args, **kwargs) self.initial(request, *args, **kwargs)這里面有權限,認證,頻率

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 欧美一极视频 | 亚洲国产二区三区 | 久久久天堂国产精品女人 | 国产免费一区二区三区 | 天天干com | 国产噜噜噜噜噜久久久久久久久 | 成人小视频在线观看 | 国产精品日韩欧美一区二区三区 | 91精品国产综合久久福利软件 | 亚洲人成网站999久久久综合 | 噜噜噜噜狠狠狠7777视频 | 91在线精品秘密一区二区 | 欧美精品一区二 | 欧美11一13sex性hd | 日本精品在线 | 亚洲视频自拍 | 日韩在线免费观看视频 | 成人免费毛片aaaaaa片 | 国产成人精品一区二区 | 一区二区中文 | 91夜夜操 | 亚洲自拍一区在线 | 亚洲精品乱码久久久久久9色 | 日本精品在线观看 | 日韩一区二区福利 | 亚洲高清中文字幕 | 性色av一二三杏吧传媒 | 久久99精品国产自在现线 | 亚洲一区不卡在线 | 欧美精品在线一区二区三区 | 精品在线一区二区 | 国产99久久久国产精品 | 日韩视频一区在线观看 | 国产亚洲欧美一区二区 | 久久久2o19精品 | 国产精品久久久久久久久免费丝袜 | 久久久久久影院 | 久久久国产一区二区三区 | 欧美日韩国产综合视频 | 美女久久久 | 久久国产精品久久久久久 |