zoukankan      html  css  js  c++  java
  • 02_View

    1、View

    1、基于类的视图 Class-based Views

    REST framework提供APIView是Django的View的子类

    发送到View的Request请求:是REST framework的Request类的实例,而不是Django的HttpRequest类的实例
    View返回的Response响应:返回REST framework的Response,而不是Django的HttpRequest

    将请求分派给处理程序方法之前,可以进行如下操作:认证,合适的权限和(或)节流检查

    View视图

    from rest_framework.views import APIView
    from rest_framework.response import Response
    from rest_framework import authentication, permissions
    from django.contrib.auth.models import User
    class ListUser(APIView):
        """
        列出系统中的所用用户的视图
    
        * 需要token认证
        * 只有管理员用户可以访问这个视图
        """
        # authentication_classes = [authentication.TokenAuthentication]   # 需要携带token访问
        permission_classes = [permissions.IsAdminUser]
    
        def get(self, request, format=None):
            """
            Return a list of all users.
            """
            usernames = [user.username for user in User.objects.all()]
            # 方法1:lowb
            # queryset = User.objects.all()
            # usernames = []
            # for user in queryset:
            #     usernames.append(user.username)
            return Response(usernames)

    url

    from django.urls import path
    from .views import ListUser, hello_world, view1, view2
    
    
    urlpatterns = [
        path('user-list', ListUser.as_view()),
    ]

    2、API策略属性

    下面这些属性控制了API视图可拔插的那些方面。

     3、API 策略实例化方法  

    下面这些方法被REST framework用来实例化各种可拔插的API策略。你通常不需要重写这些方法。

    4、API 策略实现方法

    在分派到处理程序方法之前调用以下方法。

     5、dispatch 相关方法

     

    1、.initialize_request(self, request, args, *kwargs)

    # 初始化request请求,返回Request实例

    2、.initial(self, request, args, *kwargs)

    运行在调用方法处理程序之前,运行你需要的任何功能。可以执行权限认证,节流限制,内容协商

    3、.handle_exception(self, exc)

    处理程序方法抛出的任何异常都将传递给此方,通过返回适当的响应,或重新引发错误。

    4、.finalize_response(self, request, response, args, *kwargs)

    确保从处理程序方法返回的任何 Response 对象都被渲染成正确的内容类型

    2、基于函数的视图 (Function Based Views)

    说 [基于类的视图] 永远是最好的解决方案是一个错误

    REST framework 还允许您使用常规的基于函数的视图

    urls

    from django.urls import path
    from .views import ListUser, hello_world, view1, view2
    
    
    urlpatterns = [
        path('user-list', ListUser.as_view()),
    
        # @api_view
        path('hello-world', hello_world),
        path('view1', view1),   # 节流
        path('view2', view2),   # schema api概要描述
    ]

    1、@api_view()

    语法:@api_view(http_method_names=['GET'])

    from rest_framework.decorators import api_view
    
    
    @api_view(http_method_names=['GET', 'POST'])
    def hello_world(request):
        if request.method == 'POST':
            return Response({"message": "Got some data!", "data": request.data})
        return Response({"message": "hello world!"})

    2、API 策略装饰器 (API policy decorators)

    REST framework 提供了一系列可以添加到视图中的附加装饰器

    例如,要创建一个使用限流来确保它每天只能由特定用户调用一次的视图,请使用 @throttle_classes 装饰器,传递一个限流类列表:

    from rest_framework.decorators import api_view, throttle_classes
    from rest_framework.throttling import UserRateThrottle
    
    
    class OncePerDayUserThrottle(UserRateThrottle):  # 节流:一天一次访问器
        rate = "1/day"
    
    
    @api_view(['GET'])
    @throttle_classes([OncePerDayUserThrottle])
    def view1(request):
        return Response({"message": "hello for today!see you tomorrow"})

    可用的装饰者有:

    • @renderer_classes(...)
    • @parser_classes(...)
    • @authentication_classes(...)
    • @throttle_classes(...)
    • @permission_classes(...)

     3、视图模式装饰器 (View schema decorator)

    要覆盖基于函数的视图的默认模式生成,您可以使用 @schema 装饰器

    ###
    # 视图模式装饰器 (View schema decorator)
    ###
    
    from rest_framework.schemas import AutoSchema
    from rest_framework.decorators import schema
    
    
    class CustomAutoSchema(AutoSchema):
        def get_link(self, path, mehod, base_url):
            # 这里重写视图,描述该API的概要
            pass
    
    
    @api_view(http_method_names=['GET'])
    @schema(CustomAutoSchema)
    # @schema(None)
    def view2(request):
        return Response({"message": "hello for today! see you tomorrow!"})

    3、总结

    1、APIView源码

  • 相关阅读:
    MySQL分库分表环境下全局ID生成方案
    centos添加php及mysql环境变量
    shell中的常用通配符,字符类
    centos7 安装xinetd,telnet
    centos7 systemctl一些用法
    ps命令
    nginx与php-fpm通信的两种方式
    nginx常用功能
    MySQL安装
    MySql与MariaDB由来与历程
  • 原文地址:https://www.cnblogs.com/venicid/p/12035522.html
Copyright © 2011-2022 走看看