DRF 的视图,路由和渲染器
DRF 的视图,路由和渲染器
1 视图
简单的增删改查 : ModelViewSet; 复杂的操作使用APIView 和 GenericViewSet
APIView(View)
class HomeView(APIView):
def get(self,request,*args,**kwargs):
user_list = UserInfo.objects.all()
ser = IndexSerializer(user_list,many=True)
return Response(ser.data)
GenericAPIView(APIView)
注意 GenericAPIView 和 GenericViewSet 都需要 queryset = UserInfo.objects.all(); serializer_class = IndexSerializer 否则会报错
class HomeView(GenericAPIView):
queryset = UserInfo.objects.all()
serializer_class = IndexSerializer
pagination_class = PageNumberPagination
def get(self,request,*args,**kwargs):
user_list = self.get_queryset()
p = self.paginator
page_user_list = p.paginate_queryset(queryset=user_list, request=request, view=self)
ser = IndexSerializer(page_user_list,many=True)
return p.get_paginated_response(ser.data)
GenericViewSet(ViewSetMixin, generics.GenericAPIView)
使用之后需要修改路由, 分发请求做不同的操作
注意 GenericAPIView 和 GenericViewSet 都需要 queryset = UserInfo.objects.all(); serializer_class = IndexSerializer 否则会报错
修改路由 url(r'^home/', HomeView.as_view({'get':'list','post':'create'}))
url(r'^home/(?P<id>\d+)', HomeView.as_view({'get':'retrieve'}))
修改视图的方法
class HomeView(GenericViewSet):
queryset = UserInfo.objects.all()
serializer_class = IndexSerializer
pagination_class = PageNumberPagination
def list(self,request,*args,**kwargs):
..
def create():...
def retrieve():...
ModelViewSet(mixins.CreateModelMixin,mixins.RetrieveModelMixin,mixins.UpdateModelMixin,mixins.DestroyModelMixin,mixins.ListModelMixin,GenericViewSet)
url(r'^home/$', HomeView.as_view({'get':'list','post':'create'}),name='home'),
url(r'^home/(?P<pk>\d+)$', HomeView.as_view({'get':'retrieve','put':'update','patch':'partial_update','delete':'destroy'})),
class HomeViewSet(ModelViewSet):
queryset = UserInfo.objects.all()
serializer_class = IndexSerializer
pagination_class = PageNumberPagination
# 不需要自定义方法
'get':'retrieve' == >> 权限的粒度 达到 单条对象级别,即单条数据 权限认证 check_object_permission
注意: GenericAPIView之后 , GenericViewSet ,ModelViewSet 内部都会检测 queryset和serializer_class,
都需要 queryset = UserInfo.objects.all(); serializer_class = IndexSerializer 否则会报错
2 路由
需要配置一套 .(?P\w+) 来请求不同的数据类型
自定义路由
from django.conf.urls import url, include
from web.views import s11_render
urlpatterns = [
url(r'^test/$', s11_render.TestView.as_view()),
url(r'^test\.(?P<format>[a-z0-9]+)$', s11_render.TestView.as_view()),
url(r'^test/(?P<pk>[^/.]+)/$', s11_render.TestView.as_view()),
url(r'^test/(?P<pk>[^/.]+)\.(?P<format>[a-z0-9]+)$', s11_render.TestView.as_view())
]
from rest_framework.views import APIView
from rest_framework.response import Response
from .. import models
class TestView(APIView):
def get(self, request, *args, **kwargs):
print(kwargs)
print(self.renderer_classes)
return Response('...')
半自动路由
url(r'^home/$', HomeView.as_view({'get':'list','post':'create'}),name='home'),
url(r'^home/(?P<pk>\d+)$', HomeView.as_view({'get':'retrieve','put':'update','patch':'partial_update','delete':'destroy'})),
url(r'^home\.(?P<format>\w+)$', HomeView.as_view({'get':'list','post':'create'}),name='home'),
url(r'^home/(?P<pk>\d+)\.(?P<format>\w+)$', HomeView.as_view({'get':'retrieve','put':'update','patch':'partial_update','delete':'destroy'})),
]
from rest_framework.viewsets import ModelViewSet
from rest_framework import serializers
from .. import models
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.UserInfo
fields = "__all__"
class UserViewSet(ModelViewSet):
queryset = models.UserInfo.objects.all()
serializer_class = UserSerializer
全自动路由
注意 serializer 需要使用 modelserailizer 全部字段
view 需要 viewset(对应不同的数据处理方式)
from django.conf.urls import url, include
from rest_framework import routers
from web.views import UserViewSet
router = routers.DefaultRouter()
router.register(r'users', UserViewSet)
urlpatterns = [
url(r'^', include(router.urls)),
]
from rest_framework.viewsets import ModelViewSet
from rest_framework import serializers
from .. import models
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.UserInfo
fields = "__all__"
class UserViewSet(ModelViewSet):
queryset = models.UserInfo.objects.all()
serializer_class = UserSerializer
3 渲染器
根据 用户请求URL 或 用户可接受的类型,筛选出合适的 渲染组件
renderer_classes = [JSONRenderer,BrowsableAPIRenderer,AdminRenderer]
http://127.0.0.1:8000/test/?format=json
http://127.0.0.1:8000/test.json
DRF 的视图,路由和渲染器的更多相关文章
- Django REST framework 之分页,视图,路由,渲染器
1.分页 2.视图 3.路由 4.渲染器 1.分页 方法一: from django.shortcuts import render from rest_framework.versioning im ...
- Django Rest Framework(分页、视图、路由、渲染器)
一.分页 试问如果当数据量特别大的时候,你是怎么解决分页的? 方式a.记录当前访问页数的数据id 方式b.最多显示120页等 方式c.只显示上一页,下一页,不让选择页码,对页码进行加密 1.基于lim ...
- django的rest framework框架——分页、视图、路由、渲染器
一.rest framework的分页 1.使用rest framework内置类PageNumberPagination实现分类 from django.conf.urls import url f ...
- rest_framework框架实现之(视图,路由,渲染器)
一视图 一 在前面我们使用视图时继承的时APIview from rest_framework.response import Response from rest_framework.paginat ...
- Django:之Sitemap站点地图、通用视图和上下文渲染器
Django中自带了sitemap框架,用来生成xml文件 Django sitemap演示: sitemap很重要,可以用来通知搜索引擎页面的地址,页面的重要性,帮助站点得到比较好的收录. 开启si ...
- DRF之频率限制、分页、解析器和渲染器
一.频率限制 1.频率限制是做什么的 开放平台的API接口调用需要限制其频率,以节约服务器资源和避免恶意的频繁调用. 2.频率组件原理 DRF中的频率控制基本原理是基于访问次数和时间的,当然我们可以通 ...
- DRF频率、分页、解析器、渲染器
DRF的频率 频率限制是做什么的 开放平台的API接口调用需要限制其频率,以节约服务器资源和避免恶意的频繁调用. 频率组件原理 DRF中的频率控制基本原理是基于访问次数和时间的,当然我们可以通过自己定 ...
- 【DRF解析器和渲染器】
目录 解析器 Django中的解析器 DRF中的解析器 DRF中的渲染器 @ *** 解析器 解析器的作用就是服务端接收客户端传过来的数据,把数据解析成自己想要的数据类型的过程. 本质就是对请求体中的 ...
- 07 Django REST Framework 解析器与渲染器
01-解析器 REST 框架包括一些内置的Parser类,允许你接受各种媒体类型的请求.还支持定义自己的自定义解析器,这使你可以灵活地设计API接受的媒体类型. 注意: 开发客户端应用程序时应该始终记 ...
随机推荐
- Q35+uefi or bios+legacy // PCI | PCIE
1:首先统一可扩展固件接口(UEFI)是一种规范定义操作系统和平台固件之间的软件接口. UEFI旨在替代基本输入/输出系统(BIOS)固件接口.(legacy) 硬件平台厂商越来越多地采用UEFI管理 ...
- beego——获取参数
1.获取参数 我们经常需要获取用户传递的数据,包括Get.POST等方式的请求,beego里面会自动解析这些数据,你可以通过如下方式获取数据: GetString(key string) string ...
- vue中的锚点和查询字符串
1.什么是锚点 锚点(achor):其实就是超链接的一种. 如:普通的超链接 <a href="sub_task_detail.php">详细</a> 主 ...
- Android 6.0 Kotlin 蓝牙BLE扫描(改为指定时间没有发现新设备后停止扫描使用interface)
package com.arci.myapplication import android.os.Bundleimport android.support.design.widget.Snackbar ...
- hadoop29---自定义注解
自定义注解: package cn.itcast_04_springannotation.userdefinedannotation.annotation; import java.lang.anno ...
- Web前端学习笔记之BootStrap
Bootstrap介绍 Bootstrap是Twitter开源的基于HTML.CSS.JavaScript的前端框架. 它是为实现快速开发Web应用程序而设计的一套前端工具包. 它支持响应式布局,并且 ...
- Zabbix JVM 安装
Zabbix 服务端安装插件 系统:centos 7.4 x64 环境:zabbix 3.0.16 yum源:rpm -ivh http://repo.zabbix.com/zabbix/3.0/rh ...
- jQuery/CSS3 图片边框线条变换动画
在线演示 本地下载
- nginx反向代理服务器端口问题
nginx可以很方便的配置成反向代理服务器 server { listen 80; server_name bothlog.com; location / { proxy_set_header H ...
- JAVA文件下载,页面显示另存为效果
经过测试 firefox.QQ.IE 浏览器是可以的 chrome浏览器不行(直接下载了) 1. 系统框架springmvc+jsp 2. 后台servlet代码 @RequestMapping( ...