DRF视图组件:  

CVB模式继承----五层
from django.views import View # Django的View
from rest_framework.views import APIView # drf的APIView继承View
from rest_framework.generics import GenericAPIView, CreateAPIView # drf的GenericAPIView继承APIView
# 以下CBV需要在路由的as_view()中添加对应参数---请求方式和函数的映射:无参数{'get':'list','post':'create'},带参数{'get':'retrive'}
from rest_framework.viewsets import GenericViewSet # drf的GenericViewSet继承ViewSetMixin和GenericAPIView,路由改变:需指定请求方法--视图函数映射
from rest_framework.viewsets import ModelViewSet # drf的ModelViewSet继承查(多条)、增、查(单条)、删、改和GenericViewSet,共有一个视图即可,路由有改变:需指定请求方法--视图函数(默认继承类处理)映射 一般多用APIView,对于基本的增删改查可直接使用ModelViewSet

models.py  

class UserGroup(models.Model):
title = models.CharField(max_length=10)

models.py:

urls.py

drf主路由配置urls.py  

from django.conf.urls import url,include
urlpatterns = [
url(r'^api/', include('api.urls')),
]

drf主路由配置urls.py:

api主路由配置urls.py:

from django.conf.urls import url
from api import views urlpatterns = [ # 继承APIView的路由写法
url(r'^(?P<version>v[\d+])/groups1/$', views.UserGroupView1.as_view(), ),
url(r'^(?P<version>v[\d+])/group1/(?P<pk>\d+)/$', views.UserGroupView11.as_view(), ), #继承GenericAPIView的路由写法
url(r'^(?P<version>v[\d+])/groups2/$', views.UserGroupView2.as_view(), ),
url(r'^(?P<version>v[\d+])/group2/(?P<pk>\d+)/$', views.UserGroupView22.as_view(), ), # 继承GenericViewSet的路由
url(r'^(?P<version>v[\d+])/groups3/$', views.UserGroupView3.as_view({'get':'list','post':'create'}), ),
url(r'^(?P<version>v[\d+])/group3/(?P<pk>\d+)/$', views.UserGroupView33.as_view({'get':'retrieve','put':'update','delete':'destroy'}), ),# 默认就是pk,或者自定义但需要指定但要在类中定义lookup_url_kwarg # 继承ModelViewSet的路由(执行同一个视图即可,有视图继承的不同类分别进行处理)
url(r'^(?P<version>v[\d+])/groups4/$', views.UserGroupView4.as_view({'get': 'list', 'post': 'create'}), ),
url(r'^(?P<version>v[\d+])/group4/(?P<pk>\d+)/$',
views.UserGroupView4.as_view({'get': 'retrieve', 'put': 'update', 'delete': 'destroy'}), ),
# 默认就是pk,或者自定义但需要指定但要在类中定义lookup_url_kwarg ]

api主路由配置urls.py:

views.py  

from django.shortcuts import render, HttpResponse
from rest_framework import serializers
from api import models
from rest_framework.response import Response#DRF自带,可自动进行序列化 #序列化器
class UserGroupSerializer1(serializers.ModelSerializer):
class Meta:
model = models.UserGroup
fields = "__all__" #1.继承APIView的CBV写法
from rest_framework.views import APIView
class UserGroupView1(APIView):
def get(self, request, *args, **kwargs):
groups = models.UserGroup.objects.all()
ser_groups = UserGroupSerializer1(instance=groups, many=True)
ret = ser_groups.data
return Response(ret) def post(self, request, *args, **kwargs):
ser_data = UserGroupSerializer1(data=request.data)
if ser_data.is_valid(): # 序列化器校验
ser_data.save() # 返回当前对象(序列化有instance就是更新)
else:
return Response(ser_data.errors)
return self.get(request, *args, **kwargs)
class UserGroupView11(APIView):
def get(self, request, *args, **kwargs):
pk = kwargs.get('pk')
group = models.UserGroup.objects.get(pk=pk)
ser_group = UserGroupSerializer1(instance=group) # many默认就是False
ret = ser_group.data
return Response(ret) def put(self, request, *args, **kwargs):
pk = kwargs.get('pk')
group = models.UserGroup.objects.get(pk=pk)
ser_data = UserGroupSerializer1(instance=group, data=request.data)
if ser_data.is_valid():
r = ser_data.save()
print(r)
else:
return Response(ser_data.errors)
return self.get(request, *args, **kwargs) def patch(self, request, *args, **kwargs):
pass def delete(self, request, *args, **kwargs):
pass #2.继承GenericAPIView的CBV写法(不实用--看源码)
from rest_framework.generics import GenericAPIView, CreateAPIView
class UserGroupView2(GenericAPIView):
# filter_backends#配置过滤字段
queryset = models.UserGroup.objects.all()
serializer_class = UserGroupSerializer1#指定序列化器
pagination_class = PageNumberPagination#自定分页类 def get(self, request, *args, **kwargs):
groups = self.get_queryset()
page_groups = self.paginate_queryset(groups)
ser_data = self.get_serializer(instance=page_groups, many=True)
ret =ser_data.data
return Response(ret)
def post(self,request,*args,**kwargs):
ser_data = UserGroupSerializer1(data=request.data)
if ser_data.is_valid(): # 序列化器校验
ser_data.save() # 返回当前对象(序列化有instance就是更新)
else:
return Response(ser_data.errors)
return self.get(request, *args, **kwargs) class UserGroupView22(GenericAPIView):
# filter_backends#配置过滤字段
queryset = models.UserGroup.objects.all()
serializer_class = UserGroupSerializer1
lookup_field = 'pk'#指定字段(默认)--获取单个对象用 def get(self, request, *args, **kwargs):
obj = self.get_object()
ser_data = self.get_serializer(instance=obj,many=False)
ret = ser_data.data
return Response(ret) def put(self, request, *args, **kwargs):
pk = kwargs.get('pk')
pass def delete(self, request, *args, **kwargs):
pass #3.继承GenericViewSet的CBV写法(注意路由的改变--请求与函数映射,函数名可自定义或采用默认,但必须对应)
from rest_framework.viewsets import GenericViewSet
class UserGroupView3(GenericViewSet):
queryset = models.UserGroup.objects.all()
serializer_class = UserGroupSerializer1
pagination_class = PageNumberPagination
def list(self, request, *args, **kwargs):
groups = self.get_queryset()
page_groups = self.paginate_queryset(groups)
ser_data = self.get_serializer(instance=page_groups, many=True)
ret =ser_data.data
return Response(ret)
def create(self,request,*args,**kwargs):
ser_data = UserGroupSerializer1(data=request.data)
if ser_data.is_valid(): # 序列化器校验
ser_data.save() # 返回当前对象(序列化有instance就是更新)
else:
return Response(ser_data.errors)
return Response('post--create--ok!') class UserGroupView33(GenericViewSet):
queryset = models.UserGroup.objects.all()
serializer_class = UserGroupSerializer1
lookup_field = 'pk'#指定字段(默认)--获取单个对象用 def retrieve(self, request, *args, **kwargs):
obj = self.get_object()
ser_data = self.get_serializer(instance=obj, many=False)
ret = ser_data.data
return Response(ret) def update(self, request, *args, **kwargs):
obj = self.get_object()#获取当前对象通过指定字段lookup_field
ser_data = self.get_serializer(instance=obj,data=request.data, many=False)
if ser_data.is_valid():
ser_data.save()
else:
return Response(ser_data.errors)
return HttpResponse('put--update--ok!') def destroy(self, request, *args, **kwargs):
models.UserGroup.objects.get(pk=self.lookup_field).delete()
return HttpResponse('delete--destroy--ok!') #4.继承ModelViewSet(继承6个类)的CBV写法(注意路由的改变--请求与函数(采用默认的类自己处理)映射)#针对简单的增删改查适用
from rest_framework.viewsets import ModelViewSet
class UserGroupView4(ModelViewSet):
queryset = models.UserGroup.objects.all()
serializer_class = UserGroupSerializer1
pagination_class = PageNumberPagination
lookup_field = 'pk' # 指定字段(默认)--获取单个对象用(改/删/查单个)注意与url中对应

views.py:

settings.py

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'api.apps.ApiConfig',
'rest_framework',
] REST_FRAMEWORK = {
# 版本组件
'DEFAULT_VERSIONING_CLASS': 'rest_framework.versioning.URLPathVersioning', # 设置版本组件类
'DEFAULT_VERSION': 'v1', # 默认的API版本
'ALLOWED_VERSIONS': ['v1', 'v2'], # 允许的API版本
'VERSION_PARAM': 'version', # 版本的key,默认的就是version(注意要和api接口中的key对应) # 解析器组件
'DEFAULT_PARSER_CLASSES': ['rest_framework.parsers.JSONParser', 'rest_framework.parsers.FormParser', ],
# 可指定多个解析器,不配置默认支持所有 # 分页组件
'PAGE_SIZE': 3 }

settings.py

CVB模式继承----五层

from django.views import View  # DjangoView

from rest_framework.views
import APIView 
# drfAPIView继承View

from rest_framework.generics
import GenericAPIView, CreateAPIView  # drfGenericAPIView继承APIView

# 以下CBV需要在路由的as_view()中添加对应参数---请求方式和函数的映射:无参数{'get':'list','post':'create'},带参数{'get':'retrive'}

from rest_framework.viewsets
import GenericViewSet  # drfGenericViewSet继承ViewSetMixinGenericAPIView,路由改变:需指定请求方法--视图函数映射

from rest_framework.viewsets
import ModelViewSet  # drfModelViewSet继承查(多条)、增、查(单条)、删、改和GenericViewSet,共有一个视图即可,路由有改变:需指定请求方法--视图函数(默认继承类处理)映射

一般多用APIView,对于基本的增删改查可直接使用ModelViewSet

DRF视图组件的更多相关文章

  1. DRF 视图组件

    目录 DRF 视图组件 视图组件大纲 两个视图基本类 五个扩展类 九个子类视图 视图集 常用视图集父类 魔法类 一览表 DRF中视图的"七十二变" 第一层:基于APIview的五个 ...

  2. drf视图组件、认证组件

    视图组件 1.基本视图 url(r'^publish/$', views.PublishView.as_view()), url(r'^publish/(?P<pk>\d+)/$', vi ...

  3. DRF 视图组件,路由组件

    视图组件  -- 第一次封装   -- GenericAPIView(APIView):    queryset = None    serializer_class = None    def ge ...

  4. DRF 视图组件代码

    序列化器代码 # 声明序列化器from rest_framework import serializersfrom djangoDome.models import Book class Publis ...

  5. DRF之视图组件

    不断的优化我们写的程序,是每个程序员必备的技能和职业素养,也是帮助我们成长的非常重要的手段. 使用serializer进行put接口设计 根据规范,PUT接口用来定义用户对数据修改的逻辑,也就是upd ...

  6. 【DRF框架】视图组件

    基于mixins视图类 from rest_framework import mixins # 创建视图 class CreateModelMixin(object) def create(self, ...

  7. DRF的视图组件

    目录 DRF的视图组件 两大视图类 六大视图工具类 九大工具视图类 两大视图集基类 DRF的视图组件 DRF的视图组件大概分以下几类 两大视图类 APIView.GenericAPIView from ...

  8. DRF - 序列化组件(GET/PUT/DELETE接口设计)、视图优化组件

    一.序列化组件 基于上篇随笔的表结构 , 通过序列化组件的ModelSerializer设计如下三个接口 : GET 127.0.0.1:8000/books/{id} # 获取一条数据,返回值:{} ...

  9. DRF Django REST framework 之 视图组件(四)

    引言 在我们有几十上百的视图类,都有get,post等方法,在功能类似时,会导致大量的重复代码出现,显然还有很多可以优化的地方.这也就有了视图组件,它的功能非常强大,能很好的优化接口逻辑. 视图组件 ...

随机推荐

  1. 【Linux常见命令】split命令

    split - split a file into pieces 按照指定的行数或大小分割文件 语法: split [OPTION]... [INPUT [PREFIX]] Output fixed- ...

  2. 新手上路:Laravel-控制器基础

    1.控制器在哪 Controller目录默认存放于app\Htpp\Controllers下,当然,你可以自定义这个目录: Controllers文件夹有一个控制器基类Controller.php,你 ...

  3. flask学习笔记(二)

    一.视图函数的传参方式 修改前: 目标: 传参方式改成 途径: 通过request获取参数 注意:args并不是地点类型,而是dict的一个子类,如图: immutable意思是不可变 不可变的字典转 ...

  4. 简要理解CommonJS规范

    写在前面: 一个文件就是一个模块. 另外本文中的示例代码需要在node.js环境中方可正常运行,否则将出现错误.事实上ES6已经出现了模块规范,如果使用ES6的模块规范是无需node.js环境的.因此 ...

  5. php并发加锁

    CleverCode在工作项目中,会遇到一些php并发访问去修改一个数据问题,如果这个数据不加锁,就会造成数据的错误.下面CleverCode将分析一个财务支付锁的问题. 1 没有应用锁机制 1.1 ...

  6. 数学--数论--HDU1576 A / B(逆元)

    问题描述 要求(A / B)%9973,但由于A很大,我们只被告知n(n = A%9973)(我们给定的A必能被B整除,且gcd(B,9973)= 1). 输入项 数据的第一行是一个T,表示有T组数据 ...

  7. springboot打包启动时报mybatis的typeAlias类名找不到的错误

    springBoot项目在IDEA上面正常但是打包之后运行 出错,错误大致为mybatis解析Mapper.xml时 typeAlias找不到XX类 Mapper里面的标签: <select p ...

  8. 给springboot增加XSS跨站脚本攻击防护功能

    XSS原理 xss攻击的原理是利用前后端校验不严格,用户将攻击代码植入到数据中提交到了后台,当这些数据在网页上被其他用户查看的时候触发攻击 举例:用户提交表单时把地址写成:山东省济南市<scri ...

  9. libevent(十三)evhttp事件处理流程

    在libevent(六)http server中,作为一个单线程http server,不仅要监听每个连接的到来,还要监听每个连接上的I/O事件. 查看源码可知,在evhttp_bind_socket ...

  10. JVM之类加载器、加载过程及双亲委派机制

    JVM 的生命周期 虚拟机的启动 Java 虚拟机的启动是通过引导类加载器(bootstrap class loader)创建一个初始类(initial class)来完成的,这个类是由虚拟机的具体实 ...