解析器,路由控制,响应器

解析器

urlencode,formdata,json

urlencode编码,body体中的数据格式:
name = laqz&age=18&xx =yy

json编码:{"name":"lqz","age":18}

formdata: 需要有数据部分和文件部分的分割
    
作用:
根据请求头 content-type 选择对应的解析器对请求体内容进行处理。
有application/json,x-www-form-urlencoded,form-data等格式
  
使用:
    局部使用:
        from rest_framework.parsers import JSONParser,FormParse
        parser_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=json
    http://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']
}

drf响应器的配置文件查找顺序

1.先从我们定义的视图类中找
class APIView(View):
    #我们定义的视图类继承了APIView,如果在视图类中定义了renderer(响应器,渲染器)_classes,则优先使用我们定义的
    renderer_classes = api_settings.DEFAULT_RENDERER_CLASSES

2.再从配置文件中找
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
    
 @property
    def user_settings(self):
        if not hasattr(self, '_user_settings'):
            #从配置文件的'REST_FRAMEWORK'中查找
            self._user_settings = getattr(settings, 'REST_FRAMEWORK', {})
        return self._user_settings
    
 3.从默认配置中找

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',
    )


    #from django.conf import settings,如果用户定义了就用用户的配置,如果没有定义就去默认的
原文地址:https://www.cnblogs.com/robert-zhou/p/10651712.html