ModelViewSet
-
功能
1.認證 (登錄認證)
2.權限 (規定用戶的可操作范圍)
3.限流 (限制接口訪問速度)
4.分頁
5.序列化 (返回json)
6.過濾 ()
7.排序 (ordering=-id)
8.版本 (接口版本號,用v1/v2/v3)
-
安裝DjangoRestFramework
pip install djangorestframework==3.11.1
pip install django-filter==2.3.0 #過濾器
pip install markdown -
在settings中注冊
INSTALLED_APPS = [
'Django_filter',
'rest_frameword',
] -
在settings配置DRF
# 過濾器
# 1,安裝 django-filter
# 2,注冊應用
# 3,配置settings, 在view里配置可過濾的字段
# 4,使用 查詢字符串攜帶過濾信息
REST_FRAMEWORK = {
# 文檔報錯: AttributeError: ‘AutoSchema’ object 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...",