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

    解析器

    作用:
    根据请求头 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']
    }
    

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

    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',
        )
    
    
        
    
  • 相关阅读:
    重定向是否可以重定向到post接口
    ForkJoin(工作窃取)初步使用,计算偶数集合
    Dubbo服务的三种发布模式
    mysql开启慢查询日志
    Hashmap的结构,1.7和1.8有哪些区别
    idea回滚已经push的代码
    rabbitmq集群安装配置
    restful好处,表单提交put/delete
    BIO/NIO/AIO待完成
    判断一个对象是否可以被回收
  • 原文地址:https://www.cnblogs.com/robert-zhou/p/10632795.html
Copyright © 2011-2022 走看看