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

Posted robert-zhou

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解析器,路由控制,响应器相关的知识,希望对你有一定的参考价值。

解析器

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,如果用户定义了就用用户的配置,如果没有定义就去默认的

以上是关于解析器,路由控制,响应器的主要内容,如果未能解决你的问题,请参考以下文章

Django框架深入了解_04(DRF之url控制解析器响应器版本控制分页)

DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)

路由控制和响应器

url,解释器,响应器,版本控制,分页

(了解)rest_framework之版本控制, 响应器, url控制器

Fiddler Statistics统计,Inspector检查器,AutoResponder自动响应器