Django学习之DRF-03

视图集
    1.视图集介绍
    2.视图集基本使⽤
        1.需求 使⽤视图集获取列表数据和单⼀数据
        2.实现

class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
"""使⽤视图集实现返回列表数据和单⼀数据"""
    queryset = BookInfo.objects.all()
    serializer_class = BookInfoSerializer

1.视图

2.序列化器
                可使⽤之前定义过的序列化器

class BookInfoSerializer(serializers.Serializer):
    pass
class BookInfoModelSerializer(serializers.ModelSerializer):
    pass

3.路由
                # 演示viewset

url(r'^books/$', views.BookInfoViewSet.as_view({'get': 'list'})),
url(r'^books/(?P<pk>\d+)/$', views.BookInfoViewSet.as_view({'get': 'retrieve'})),

3.视图集中定义附加action动作
        1.需求
            追加读取倒叙后的最新数据逻辑
            追加修改阅读量的逻辑
        2.实现
            1.视图

class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
"""使⽤视图集实现返回列表数据和单⼀数据"""
    queryset = BookInfo.objects.all()
    serializer_class = BookInfoSerializer
    # 以下代码: 演示附加action逻辑
    def latest(self, request):
    """
    返回最新的图书信息
    """
        book = BookInfo.objects.latest('id')
        serializer = self.get_serializer(book)
        return Response(serializer.data)
    def read(self, request, pk):
    """
    修改图书的阅读量数据
    """
        book = self.get_object()
        book.bread = request.data.get('read')
        book.save()
        serializer = self.get_serializer(book)
        return Response(serializer.data)

2.路由

# 演示viewset
url(r'^books/$', views.BookInfoViewSet.as_view({'get': 'list'})),
url(r'^books/(?P<pk>\d+)/$', views.BookInfoViewSet.as_view({'get': 'retrieve'})),
# 演示附加action
url(r'^books/latest/$', views.BookInfoViewSet.as_view({'get': 'latest'})),
url(r'^books/(?P<pk>\d+)/read/$', views.BookInfoViewSet.as_view({'put': 'read'})),

4.路由Routers
        1.介绍
            REST framework提供了两个router
            • SimpleRouter
            • DefaultRouter
        2.需求 使⽤DefaultRouter定义路由
        3.实现
            1.原有路由
                # 演示viewset
                url(r'^books/$', views.BookInfoViewSet.as_view({'get': 'list'})),
                url(r'^books/(?P<pk>\d+)/$', views.BookInfoViewSet.as_view({'get': 'retrieve'})),
                # 演示附加action
                url(r'^books/latest/$', views.BookInfoViewSet.as_view({'get': 'latest'})),
                url(r'^books/(?P<pk>\d+)/read/$', views.BookInfoViewSet.as_view({'put': 'read'})),
            2.视图集中附加action的声明
            3.DefaultRouter定义路由
                # 创建路由对象
                router = DefaultRouter()
                # 将视图集注册到路由
                router.register(r'books', views.BookInfoViewSet, base_name= 'book')
                # 视图集路由添加到urlpatterns
                urlpatterns += router.urls

视图⾼级⽤法
    1.认证Authentication
        1.说明 识别登录⽤户是谁
        2.配置
            # DRF配置

REST_FRAMEWORK = {
            'DEFAULT_AUTHENTICATION_CLASSES': (
            'rest_framework.authentication.BasicAuthentication', # 基本认证
            'rest_framework.authentication.SessionAuthentication', # session认证
            )
            }

3.补充
            认证失败会有两种可能的返回值:
            • 401 Unauthorized 未认证
            • 403 Permission Denied 权限被禁⽌
            2.权限Permissions
            1.说明
                权限控制可以限制⽤户对于视图的访问和对于具体数据对象的访问。
                • 在执⾏视图的dispatch()⽅法前,会先进⾏视图访问权限的判断
                • 在通过get_object()获取具体对象时,会进⾏对象访问权限的判断
                限制⽤户的权限
                提供的权限
                • AllowAny 允许所有⽤户
                • IsAuthenticated 仅通过认证的⽤户
                • IsAdminUser 仅管理员⽤户
                • IsAuthenticatedOrReadOnly 认证的⽤户可以完全操作,否则只能get读取
    2.视图访问权限
        1.全局权限

REST_FRAMEWORK = {
            'DEFAULT_PERMISSION_CLASSES': (
            'rest_framework.permissions.IsAuthenticated',
            )
           }

2.局部权限
            class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
            """使⽤视图集实现返回列表数据和单⼀数据"""
                queryset = BookInfo.objects.all()
                serializer_class = BookInfoSerializer
                # 权限认证: 只有登录⽤户才能访问
                permission_classes = [IsAuthenticated]
                pass
        3.⾃定义权限
        1.说明
            如需⾃定义权限,需继承rest_framework.permissions.BasePermission⽗类,并实现以下两个任何⼀个⽅法或全部
            • .has_permission(self, request, view)
        是否可以访问视图, view表示当前视图对象
             • .has_object_permission(self, request, view, obj)
        是否可以访问数据对象, view表示当前视图, obj为数据对象
        2.实现

class MyPermission(BasePermission):
    def has_object_permission(self, request, view, obj):
    """控制对obj对象的访问权限,此案例决绝所有对对象的访问"""
        return False
    class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
    """使⽤视图集实现返回列表数据和单⼀数据"""
        queryset = BookInfo.objects.all()
        serializer_class = BookInfoSerializer
        # 权限认证: 只有登录⽤户才能访问,且⽆权访问单⼀对象
        permission_classes = [IsAuthenticated, MyPermission]
        pass

3.限流Throttling
        1.说明 可以对接⼝访问的频次进⾏限制,以减轻服务器压⼒。
        2.配置

DEFAULT_THROTTLE_RATES 可以使⽤ second, minute, hour 或 day来指明周期。
# DRF配置
REST_FRAMEWORK = {
      'DEFAULT_THROTTLE_CLASSES': (
      'rest_framework.throttling.AnonRateThrottle', # 匿名⽤户限流
      'rest_framework.throttling.UserRateThrottle' # 登录⽤户限流
      ),
      'DEFAULT_THROTTLE_RATES': {
      'anon': '1/minute', # 匿名⽤户限流
      'user': '3/minute' # 登录⽤户限流
      }
}

4.过滤Filtering
        1.安装过滤模块 pip install django-filter
        2.注册应⽤

INSTALLED_APPS = [
      ' django.contrib.admin' ,
      ' django.contrib.auth' ,
      ' django.contrib.contenttypes' ,
      ' django.contrib.sessions' ,
      ' django.contrib.messages' ,
      ' django.contrib.staticfiles' ,
      'rest_framework', # DRF
      ' django_filters' , # DRF过滤
      'users.apps.UsersConfig', # 安装users应⽤, 演示基本使⽤
      'request_response.apps.RequestResponseConfig', # 演示请求和响应
      ' booktest.apps.BooktestConfig' , # 图书英雄管理应⽤
      ]

3.配置过滤后端

# DRF配置
REST_FRAMEWORK = {
    # 过滤后端
    'DEFAULT_FILTER_BACKENDS': (' django_filters.rest_framework.DjangoFilterBackend' ,)
    }

4.视图添加过滤字段

class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
"""使⽤视图集实现返回列表数据和单⼀数据"""
    queryset = BookInfo.objects.all()
    serializer_class = BookInfoSerializer
    # 权限认证: 只有登录⽤户才能访问,且⽆权访问单⼀对象
    permission_classes = [IsAuthenticated, MyPermission]
    # 过滤字段
    filter_fields = (' btitle' , 'bread')

5.测试 http://127.0.0.1:8000/books/?btitle= ⻄游记
            http://127.0.0.1:8000/books/?bread=10
    5.排序OrderingFilter
    6.分⻚Pagination
    7.版本Versioning
    8.异常处理 Exceptions
    9.⾃动⽣成接⼝⽂档

相关源码连接:

github,技术交流,欢迎指教

django 学习之DRF (三)的更多相关文章

  1. Django学习笔记(三)—— 型号 model

    疯狂暑期学习 Django学习笔记(三)-- 型号 model 參考:<The Django Book> 第5章 1.setting.py 配置 DATABASES = { 'defaul ...

  2. django 学习之DRF (二)

    Django学习之DRF02 Serializer序列化器之反序列化操作    1.调⽤序列化器进⾏验证        0.准备序列化器 class BookInfoSerializer(serial ...

  3. Django 学习笔记(三)模板导入

    本章内容是将一个html网页放进模板中,并运行服务器将其展现出来. 平台:windows平台下Liunx子系统 目前的目录: hello ├── manage.py ├── hello │ ├── _ ...

  4. django 学习之DRF (一)

    Django框架基础DRF-01 前后端分离介绍 1.前后端不分离图解 2.前后端分离图解     3.为什么要学习DRF    DRF可以帮助我们开发者快速的开发⼀个依托于Django的前后后端分离 ...

  5. Django 学习笔记(三) --- HTML 模版加载 css、js、img 静态文件

    人生苦短 ~ Tips:仅适用于 Python 3+(反正差别不大,py2 改改也能用).因为据 Python 之父 Guido van Rossum 说会在 2020 年停止对 Python 2 的 ...

  6. Django学习笔记第三篇--关于响应返回

    一.返回简单类型: #1.返回简单字符串 #from django.http import HttpResponse return HttpResponse("return string&q ...

  7. django学习笔记(三)模型

    1.创建一个django app: python manage.py startapp books 2.validate 命令检查你的模型的语法和逻辑是否正确.一旦你觉得你的模型可能有问题,运行 py ...

  8. python Django 学习笔记(三)—— 模版的使用

    模版基本介绍 模板是一个文本,用于分离文档的表现形式和内容. 模板定义了占位符以及各种用于规范文档该如何显示的各部分基本逻辑(模板标签). 模板通常用于产生HTML,但是Django的模板也能产生任何 ...

  9. python之Django学习笔记(三)---URL调度/URL路由

    在django中,用户发起url请求消息首先到工程的urls.py中查找是否有匹配的url路径 刚创建好的工程中urls.py只有下面几行代码: from django.contrib import ...

随机推荐

  1. HTML5一些元素的整理

    address元素: 定义和用法 <address> 标签定义文档或文章的作者/拥有者的联系信息. 如果 <address> 元素位于 <body> 元素内,则它表 ...

  2. Weblogic wls RCE 漏洞验证POC

    #!/usr/bin/env python # coding:utf-8 # @Date : 2017/12/22 17:11 # @File : weblogic_poc.py # @Author ...

  3. 2015.1.8 Left join 左连接

    格式 select f1.a, f2.b form f1 left jion f2 on .... 注意:左边的查询部分只能有select和from,不能出现where order by等.若有必须在 ...

  4. 第九章 Java中线程池

    Java中的线程池是运用场景最多的并发框架,几乎所有需求异步或并发执行任务的程序都可以使用线程池.在开发过程中,合理地使用线程池能够带来3个好处. 降低资源消耗:通过重复利用已创建的线程降低线程创建和 ...

  5. 对数组名取地址 a[ ],&a

    C语言规定,数组名代表数组的首地址,也就是第0号元素的地址.所以a==&a[0] 但对数组名取地址时却要注意了,在理解“对数组名取地址”这一表达式的含义时一定要记住:数组名是“数组”这种变量的 ...

  6. CDOJ1324-卿学姐与公主 【线段树点更新】

    http://acm.uestc.edu.cn/#/problem/show/1324 卿学姐与公主 Time Limit: 2000/1000MS (Java/Others)     Memory ...

  7. WCF客户端调用并行最大同时只支持两个请求

    做项目的时候发现 频繁调用WCF服务时 明明一次性发起了几十个请求 而在服务端记录的日志却显示出现了排队的迹象 并且都是最大并发数为2 在网上狂搜 大家给出来的解决方法都是增加web.config里面 ...

  8. Swing界面组件的通用属性

    ----------------siwuxie095                             Swing 界面组件(控件)的通用属性:         (1)enabled:启用/禁用 ...

  9. C++实现数组的排序/插入重新排序/以及逆置操作

    插入新的数字重新排序 分析:将新的数字与已经排序好的数组中的数字一一比较,直到找到插入点,然后将插入点以后的数字都向后移动一个单位(a[i+1]=a[i]),然后将数据插入即可. 代码: #inclu ...

  10. DB2--sql计算时间差和格式化时间

    格式化时间 db2 格式化时间使用的 TO_CHAR(TIMESTAMP('2017-10-24 21:18:12'),'YYYY-MM-DD'): 测试sql:SELECT TO_CHAR(TIME ...