drf 解析器,响应器,路由控制
生活随笔
收集整理的這篇文章主要介紹了
drf 解析器,响应器,路由控制
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
解析器
作用: 根據請求頭 content-type 選擇對應的解析器對請求體內容進行處理。 有application/json,x-www-form-urlencoded,form-data等格式使用:局部使用:from rest_framework.parsers import JSONParser,FormParseparser_classes = [JSONParser, ]全局使用:REST_FRAMEWORK = {'DEFAULT_PARSER_CLASSES':['rest_framework.parsers.JSONParser''rest_framework.parsers.FormParser''rest_framework.parsers.MultiPartParser'] }局部使用指定的解析器:parser_classes = [JSONParser, ]路由控制
三種 1.基本路由:url(r'^admin/', admin.site.urls) 2.半自動路由: url(r'^users/$', views.Users.as_view({'get':'list','post':'create'})),必須繼承:ViewSetMixin,繼承順序3.from django.conf.urls import url,include from app01 import views from rest_framework import routers router=routers.DefaultRouter() # 兩個參數,一個是匹配的路由,一個是視圖中寫的CBV的類 router.register('publish',views.PublishView) urlpatterns = [# http://127.0.0.1:8000/publish/format=json(渲染器通過這個判斷,返回渲染的頁面)# url(r'^publish/', views.PublishView.as_view({'get':'list','post':'create'})),# http://127.0.0.1:8000/publish.json(渲染器通過這個判斷,返回渲染的頁面)# url(r'^publish\.(?P<format>\w+)$', views.PublishView.as_view({'get':'list','post':'create'})),# 可以用 以下方式訪問# 1 http://127.0.0.1:8000/publish/# 2 http://127.0.0.1:8000/publish.json# 3 http://127.0.0.1:8000/publish/3# 4 http://127.0.0.1:8000/publish/3.json url(r'',include(router.urls)) ]響應器
一般不需要配置,使用默認的作用: 根據 用戶請求URL 或 用戶可接受的類型,篩選出合適的 渲染組件。 用戶請求URL:http://127.0.0.1:8000/test/?format=jsonhttp://127.0.0.1:8000/test.json內置的響應器 顯示json格式:JSONRenderer http://127.0.0.1:8000/test/?format=json http://127.0.0.1:8000/test.json http://127.0.0.1:8000/test/默認顯示格式:BrowsableAPIRenderer(可以修改它的html文件) http://127.0.0.1:8000/test/?format=api http://127.0.0.1:8000/test.api http://127.0.0.1:8000/test/表格方式:AdminRenderer http://127.0.0.1:8000/test/?format=admin http://127.0.0.1:8000/test.admin http://127.0.0.1:8000/test/form表單方式:HTMLFormRenderer http://127.0.0.1:8000/test/?format=form http://127.0.0.1:8000/test.form http://127.0.0.1:8000/test/局部使用: from rest_framework.renderers import HTMLFormRenderer,BrowsableAPIRenderer class BookDetailView(APIView):renderer_classes = [HTMLFormRenderer,BrowsableAPIRenderer ]全局使用:REST_FRAMEWORK = {'DEFAULT_RENDERER_CLASSES':['rest_framework.renderers.JSONRenderer'] }響應器的配置文件查找順序
1.先從我們定義的視圖類中找 class APIView(View):#我們定義的視圖類繼承了APIView,如果在視圖類中定義了renderer(響應器,渲染器)_classes,則優先使用我們定義的renderer_classes = api_settings.DEFAULT_RENDERER_CLASSES2.再從配置文件中找 api_settings.DEFAULT_RENDERER_CLASSES #api_settings如果沒有DEFAULT_RENDERER_CLASSES屬性,會觸發__getattr__方法def __getattr__(self, attr):...try:#先從user_settings中查找val = self.user_settings[attr]except KeyError:#如果沒有找到,從默認配置中找val = self.defaults[attr]if attr in self.import_strings:val = perform_import(val, attr)self._cached_attrs.add(attr)setattr(self, attr, val)return val@propertydef user_settings(self):if not hasattr(self, '_user_settings'):#從配置文件的'REST_FRAMEWORK'中查找self._user_settings = getattr(settings, 'REST_FRAMEWORK', {})return self._user_settings3.從默認配置中找def __init__(self, user_settings=None, defaults=None, import_strings=None):if user_settings:...#可以實例化的時候傳入self.defaults = defaults or DEFAULTS #默認的配置文件 DEFAULTS = {# Base API policies'DEFAULT_RENDERER_CLASSES': ('rest_framework.renderers.JSONRenderer','rest_framework.renderers.BrowsableAPIRenderer',)轉載于:https://www.cnblogs.com/robert-zhou/p/10632795.html
總結
以上是生活随笔為你收集整理的drf 解析器,响应器,路由控制的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【题解】Luogu P2347 砝码称重
- 下一篇: LOJ2980 THUSC2017大魔法