Django DRF APIView原始碼執行流程詳解
阿新 • • 發佈:2020-08-19
首先寫一個簡單的drf介面
from rest_framework.views import APIView from rest_framework.response import Response # 基於drf寫介面,cbv class 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,**kwargs): name = request.data.get('name') print(name) return HttpResponse('ok')
url(r'DrfTest/',views.DrfTest.as_view()),
通過路由配置 點入檢視原始碼,首先進入到APIView的as_view的方法中:
查詢dispatch方法:
如果自己所定義的class DrfTest(APIView)沒有手擼dispatch的情況下,下一步,找到APIView裡的dispatch方法:
當中有一個self.initial(request,**kwargs)方法:
至此,簡單分析如上:回到最開始定義類的過程:
流程總結
- 請求來了,執行了View類中as_view的view()方法,本質上執行了self.dispatch方法
- 按順序查詢dispatch方法(自己類中,父類中,父父類中...)
- 在APIView中的dispatch方法中先把原來request封裝進去,變成新的request物件
- 接下來又執行了三個元件,分別是認證,許可權和頻率
- 如果三個中有一個不滿足,則不繼續執行
- 再走分發方法,最後返回response出去
- 即在請求進入檢視函式前加了一些東西,重寫了dispatch方法
dispatch方法:
- 傳入的request是原生的request物件
- 這個request已經不是原生的request了,但是它內部有個原生的request物件
- request = self.initialize_request(request,**kwargs)
- self.initial(request,**kwargs)這裡面有許可權,認證,頻率
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。