#路由层 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方法
python
view = super().as_view(**initkwargs)调用父类的as_view 也就是django原生的base.py中的as_view
以后再此基础上增长了 return csrf_exempt(view) 继承了APIView的视图类,会禁用csrf认证,这样就须要在settings中注释
django
在第二步是调用父类的as_view方法,此方法中有个关键的分发方法return self.dispatch(request, *args, kwargs) (入口:view = super().as_view(initkwargs))
函数
APIView中重写了dispatch方法
源码分析
完成任务方法交给视图类的请求函数处理,获得请求的相应结果,返回给前台post