zoukankan      html  css  js  c++  java
  • modelviewset与apiview

    modelviewset(认证,权限,限流,序列化,分页,过滤,排序)

    1.DRF初始化

    1.认证(让用户登录)

    2.权限(根据不同用户角色,可以操作不同的表)

    3.限流(限制接口访问速度)

    4.序列化(返回json)

    5.分页

    6.版本(接口版本号,用v1/v2/v3)

    7.过滤(username=zhangsan)

    8.排序(ordering=-id)

    1.1安装DjangoRestFramework

    pip install djangorestframework

    pip install django-filter

    pip install markdown

    1.2在syl/settings.py中配置

    INATALLED_APPS = [

            'django_filters',

            'rest_framework',

    ]

    1.3 syl/settings.py配置DRF

    # 过滤器

    # 1,安装 django-filter

    # 2,注册应用

    # 3,配置settings, view里配置可过滤的字段

    # 4,使用 查询字符串携带过滤信息

    REST_FRAMEWORK = {

        # 文档报错: AttributeError: AutoSchemaobject has no attribute get_link

        # 用下面的设置可以解决

        'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.AutoSchema',

        # 默认设置是:

        # 'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.openapi.AutoSchema',

        # 异常处理器

        # 'EXCEPTION_HANDLER': 'user.utils.exception_handler',

        # Base API policies

        'DEFAULT_RENDERER_CLASSES': [

            'rest_framework.renderers.JSONRenderer',

            'rest_framework.renderers.BrowsableAPIRenderer',

        ],

        'DEFAULT_PARSER_CLASSES': [

            'rest_framework.parsers.JSONParser',

            'rest_framework.parsers.FormParser',

            'rest_framework.parsers.MultiPartParser'

        ],

        # 1.认证器(全局)

        'DEFAULT_AUTHENTICATION_CLASSES': [

            'rest_framework.authentication.SessionAuthentication',  # 使用session时的认证器

            'rest_framework.authentication.BasicAuthentication'     # 提交表单时的认证器

        ],

        #2.权限配置(全局): 顺序靠上的严格

        'DEFAULT_PERMISSION_CLASSES': [

            # 'rest_framework.permissions.IsAdminUser',  # 管理员可以访问

            # 'rest_framework.permissions.IsAuthenticated',  # 认证用户可以访问

            # 'rest_framework.permissions.IsAuthenticatedOrReadOnly',  # 认证用户可以访问, 否则只能读取

            # 'rest_framework.permissions.AllowAny',  # 所有用户都可以访问

        ],

        #3.限流(防爬虫)

        'DEFAULT_THROTTLE_CLASSES': [

            'rest_framework.throttling.AnonRateThrottle',

            'rest_framework.throttling.UserRateThrottle',

        ],

        #3.1限流策略

        'DEFAULT_THROTTLE_RATES': {

            'user': '100/hour',    # 认证用户每小时100

            'anon': '3/day',       # 未认证用户每天能访问3

        },

        'DEFAULT_CONTENT_NEGOTIATION_CLASS': 'rest_framework.negotiation.DefaultContentNegotiation',

        'DEFAULT_METADATA_CLASS': 'rest_framework.metadata.SimpleMetadata',

        'DEFAULT_VERSIONING_CLASS': None,

        #4.分页(全局):全局分页器, 例如 省市区的数据自定义分页器, 不需要分页

        'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',

        # 每页返回数量

        'PAGE_SIZE': 10,  # 默认 None

        #5.过滤器后端

        'DEFAULT_FILTER_BACKENDS': [

            'django_filters.rest_framework.DjangoFilterBackend',

            # 'django_filters.rest_framework.backends.DjangoFilterBackend', 包路径有变化

        ],

        #5.1过滤排序(全局):Filtering 过滤排序

        'SEARCH_PARAM': 'search',

        'ORDERING_PARAM': 'ordering',

        'NUM_PROXIES': None,

        #6.版本控制:Versioning  接口版本控制

        'DEFAULT_VERSION': None,

        'ALLOWED_VERSIONS': None,

        'VERSION_PARAM': 'version',

        # Authentication  认证

        # 未认证用户使用的用户类型

        'UNAUTHENTICATED_USER': 'django.contrib.auth.models.AnonymousUser',

        # 未认证用户使用的Token

        'UNAUTHENTICATED_TOKEN': None,

        # View configuration

        'VIEW_NAME_FUNCTION': 'rest_framework.views.get_view_name',

        'VIEW_DESCRIPTION_FUNCTION': 'rest_framework.views.get_view_description',

        'NON_FIELD_ERRORS_KEY': 'non_field_errors',

        # Testing

        'TEST_REQUEST_RENDERER_CLASSES': [

            'rest_framework.renderers.MultiPartRenderer',

            'rest_framework.renderers.JSONRenderer'

        ],

        'TEST_REQUEST_DEFAULT_FORMAT': 'multipart',

        # Hyperlink settings

        'URL_FORMAT_OVERRIDE': 'format',

        'FORMAT_SUFFIX_KWARG': 'format',

        'URL_FIELD_NAME': 'url',

        # Encoding

        'UNICODE_JSON': True,

        'COMPACT_JSON': True,

        'STRICT_JSON': True,

        'COERCE_DECIMAL_TO_STRING': True,

        'UPLOADED_FILES_USE_URL': True,

        # Browseable API

        'HTML_SELECT_CUTOFF': 1000,

        'HTML_SELECT_CUTOFF_TEXT': "More than {count} items...",

        # Schemas

        'SCHEMA_COERCE_PATH_PK': True,

        'SCHEMA_COERCE_METHOD_NAMES': {

            'retrieve': 'read',

            'destroy': 'delete'

        },

    }

    1.4创建user/seralizers.py写序列化器

    2.DRF认证,权限,限流,分页,过滤,序列化

     

     

     

     

  • 相关阅读:
    java Cache
    世界上第一个免费的云
    网上看到的一些IT资源
    图片压缩优化kraken
    Asp.net MVC Comet推送
    jQuery插件开发方式
    jQuery之Nestable
    jqGrid使用记录
    Windbg符号与源码 《第二篇》
    jQuery 获取 URL信息
  • 原文地址:https://www.cnblogs.com/GlfLss/p/13745869.html
Copyright © 2011-2022 走看看