drf : 请求(Request)与响应(Response),全局设置和局部设置drf的默认配置项。
请求(Request)与响应(Response)
请求(Request),当次的HTTP响应请求到Django中被封装成python中的对象
- request.data - POST, PUT请求的数据
- request.query_params -GET请求的数据
REST framework 传入视图的request对象不再是Django默认的HttpRequest对象,而是REST framework提供的扩展了HttpRequest类的Request类的对象。
REST framework 提供了Parser解析器,在接收到请求后会自动根据Content-Type指明的请求数据类型(如JSON、表单等)将请求数据进行parse解析,解析为类字典[QueryDict]对象保存到Request对象中。
Request对象的数据是自动根据前端发送数据的格式进行解析之后的结果。
无论前端发送的哪种格式的数据,我们都可以以统一的方式读取数据。
响应(Response),主要:data(HTTP的响应体),status(状态码),headers(HTTP的响应头)
rest_framework.response.Response
- 继承关系 ---> SimpleTemplateResponse ---> django的HttpResponse
构造方式
Response(data, status=None, template_name=None, headers=None, content_type=None)
data
数据不要是render处理之后的数据,只需传递python的内建类型数据即可,REST framework会使用renderer
渲染器处理data
。
data
不能是复杂结构的数据,如Django的模型类对象,对于这样的数据我们可以使用Serializer
序列化器序列化处理后(转为了Python字典类型)再传递给data
参数。
参数说明:
data
: 为响应准备的序列化处理后的数据;status
: 状态码,默认200;template_name
: 模板名称,在浏览器访问看达到的模板,如果使用HTMLRenderer
时需指明;headers
: 用于存放响应头信息的字典;content_type
: 响应数据的Content-Type,通常此参数无需传递,REST framework会根据前端所需类型数据来设置该参数。
可以在rest_framework.settings查找所有的drf默认配置项
全局配置,在项目的settings.py 配置。
# 1. 后期 drf 的所有配置都写在这个字典中
# 2. drf有个默认配置文件(drf源码的--setting.py),如果没有写项目的配置文件,则使用内置的,写了优先使用项目的。
# 3. 返回样式的配置,一般不配置。
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': ( # 默认响应渲染类
'rest_framework.renderers.JSONRenderer', # json渲染器
'rest_framework.renderers.BrowsableAPIRenderer', # 浏览API渲染器
)
}
局部配置,只针对某个视图函数。
导入模块:
from rest_framework.renderers import BrowsableAPIRenderer, JSONRenderer
class BookView(APIView):
# 局部配置。尽管全局配置了,优先使用局部的。
renderer_classes = [JSONRenderer]
def post(self, request):
print(request)
ser = BookSerializers(data=request.data)
if ser.is_valid():
ser.save()
return Response(ser.data)
def get(self, request):
book_list = Books.objects.all()
# many=True 代表序列化多条数据
ser = BookSerializers(instance=book_list, many=True)
"""
<class 'rest_framework.serializers.ListSerializer'>
ser 是ListSerializer的对象
"""
print(type(ser))
response = {'code': 100, 'msg': '查询成功', 'result': ser.data}
#
return Response(response, status=status.HTTP_202_ACCEPTED, headers={'name': 'junjie'})