zoukankan      html  css  js  c++  java
  • 解析器,路由控制,响应器

    解析器

    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,如果用户定义了就用用户的配置,如果没有定义就去默认的
    
  • 相关阅读:
    Codeforces 1137E 凸包
    Codeforces 1142D Foreigner (DP)
    Codeforces 1120C Compress String(DP)
    gym
    Codeforces 1142B Lynyrd Skynyrd
    PTA 估值一亿的AI核心代码
    HDU 6162 树链剖分
    洛谷P2146 树链剖分
    HTTP深入浅出http请求(转)-----http请求的过程和实现机制
    css实现不定宽高的div水平、垂直居中
  • 原文地址:https://www.cnblogs.com/robert-zhou/p/10651712.html
Copyright © 2011-2022 走看看