DRF请求生命周期
- 根据应用中urls.py,走as_view方法,但是视图类没有该方法,所以请求走的是APIView的as_view方法
- 在APIView的as_view调用父类(django原生View)的as_view,同时还禁用了 csrf 认证
- 在父类(django原生View)的as_view中dispatch方法请求走的又是APIView的dispatch
因为APIView也可以走dispatch,视图类是先继承APIView,APIView中没有再去原生View中 - 完成任务分发,交给视图类的请求函数处理,得到请求的响应结果,返回给前台,所以以后直接就从APIView的dispatch入口看源码
前期准备
#路由层 urls.py:
from django.conf.urls import url,include
from django.contrib import admin
from . import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^test/', views.test.as_view()),
]
#视图层 views.py
from django.shortcuts import render
from rest_framework.views import APIView
from rest_framework.response import Response
class test(APIView):
def get(self,reqeust,*args,**kwargs):
return Response('drf get ok')
def post(self,request,*args,**kwargs):
return Response('drf post ok')
源码分析
-
根据应用中urls.py,走as_view方法,但是视图类没有该方法,所以请求走的是APIView的as_view方法
-
view = super().as_view(**initkwargs)调用父类的as_view 也就是django原生的base.py中的as_view
之后再此基础上增加了 return csrf_exempt(view) 继承了APIView的视图类,会禁用csrf认证,这样就需要在settings中注释
-
在第二步是调用父类的as_view方法,此方法中有个关键的分发方法return self.dispatch(request, *args, kwargs) (入口:view = super().as_view(initkwargs))
-
APIView中重写了dispatch方法
-
完成任务方法交给视图类的请求函数处理,得到请求的相应结果,返回给前台