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