一、昨日内容复习
"""
1、html常用标签
2、css选择器,css三种布局
3、js四种变量,js字符串、数组、对象的操作方法,js可变长参数
4、接口的四个核心部分:请求方式,请求地址,请求参数,响应结果
5、接口工具:写接口文档的YApi平台,访问接口的Postman工具
6、restful接口规范:如何设计url,请求方式代表操作方式,网络状态码及其含义,响应结果
7、基于原生django书写满足restful规范的接口:两个url 对应 一个视图类 完成 十大接口
8、CBV请求生命周期:as_view()完成路由匹配 => url请求会调用as_view()的返回值视图函数view => 调用dispatch()完成请求分发 => 视图类的具体视图方法处理请求 => 返回给前台
9.
安装drf:pip install djangorestframework
视图类继承drf的APIView: from rest_framework.views import APIView
读懂drf的as_view()方法:返回视图函数view是,局部禁用了csrf认证 - csrf_exempt(view)
请求分发的dispatch(),
在分发执行视图方法前,完成了
二次封装request:self.initialize_request(request, *args, **kwargs)
三大认证:self.initial(request, *args, **kwargs)
在视图方法处理完请求后:
出现异常的处理:self.handle_exception(exc)
二次封装response:self.finalize_response(request, response, *args, **kwargs)
10、自己看drf源码入口:直接查看 rest_framework.view的APIView的dispatch方法
"""
二、今日学习内容
"""
1、请求模块:drf的request是对wsgi的request二次封装,且完全兼容,拓展query_params和data两个属性
request._request
request._request = request
request.query_params = request._request.GET
request.data(form-data,urlencoded,json)
2、渲染模块:可以全局和局部配置渲染方式
renderer_classes = []
DEFAULT_RENDERER_CLASSES: []
3、解析模块:可以全局和局部配置能解析的数据包
parser_classes = []
DEFAULT_PAARSER_CLASSES: []
4、异常模块:自定义异常模块,可以自定义异常返回以及提供记录异常的接口(这里接口的意思就是该需求后期可以在这里添加)
'EXCEPTION_HANDLER': 'api.utils.exception_handler',
from rest_framework.views import exception_handler as drf_exception_handler
def exception_handler(exc, context):
response = drf_exception_handler(exc, context)
if respose is None:
return Response(自己处理) # 服务器错误 500
return response # drf处理的,客户端错误 4xx
5、响应模块:知道response对象产生可以传那些信息,response对象又是如何访问这些信息的
Response(data={}, status=status.HTTP_200_OK, headers={})
"""
三、今日练习
练习A
"""
1、整理今天所学知识点
2、简单过过请求模块的源码流程,建立一个视图类,完成一项渲染模块与解析模块的全局局部配置
3、在自己项目中自定义一下异常处理函数,并配置给项目
"""
练习B
"""
1、后期项目会出现大量的响应,响应数据可以如下
正确的:Response({'status':0,'msg':'ok','results':[]})
异常的:Response({'status':1,'msg':'error'}, status=400)
...
能不能二次封装Response类(自定义一个APIResponse类继承Response),优化响应
正确的:APIResponse('results'=[]) # 数据状态码和状态信息有默认值,可以不传
异常的:Response(1,'error', status=400) # 可以按位传数据状态码和状态信息,错误时还可以设置网络状态码
封装后的响应与封装前的响应结果一致,但是大大简化了响应写法
"""