自我总结58
概况
"""
1、接口:url链接+请求方式+请求参数+响应数据结果
2、接口文档:将接口的四部分翻译成文档形式 - word、md、Yapi
3、接口测试工具:Postman
4、接口规范:
链接:https://api.bai.com/v2/users/?ordering=-uid
请求方式:查get、增post、删delete、整改put、局改patch
响应:网络状态码、数据状态码、数据状态信息、数据体(子资源)
5、十大接口:单群查|单群增|单群整体改|单群局部改|单群删
6、CBV源码:as_view() => view() => dispatch() => 视图类的视图方法get|post...
7、debug窗口的使用
"""
drf
django-restframework
作用:写接口
"""
1、接口:接口的概念、数据接口文档、接口规范(restful)、Postman接口测试工具
2、drf请求生命周期 - CBV
3、drf的基础组件:请求、响应、渲染、解析、异常
4、drf的序列化(核心):序列化、模型序列化、群操作序列化
5、drf的视图家族:视图类(常用)、视图工具类、工具视图类(常用)、视图集
6、drf的三大认证(核心):认证、权限、频率
7、drf的过滤:筛选、搜索、排序、分页、区间、自定义
"""
drf框架安装
"""
drf框架安装:
1)drf是Django的插件,所以要提前按照Django
2)按照命令:pip install djangorestframework
3)使用drf时,要在settings中注册
"""
接口
规定了提交请求参数的请求方式、访问其可以获取响应的反馈数据的url链接
返回数据的url,前后端信息交互规则的url,也是交互的媒介
如何写
参照某种规则书写url链接 同时按照规则制定请求方式,通过数据与响应结果
组成
四部分:url链接 + 请求方式 + 请求参数 + 响应数据
url链接:https://api.*com/users/
请求方式:get
请求参数{...}
响应结果{...}
接口文档
将接口的四部分翻译成文档形式 ,提供给前后台开发人员与测试人员查看 QA测试 (补充:review---给经理查看 分支的合并或代码的提交 )
yapi
接口文档平台
公司内网搭的yapi写接口
接口规范
webapi规范:restful
"""
url链接:
1)接口都是操作前后台数据的,所以需要保证数据的安全性
采用https协议
2)接口用来操作数据,与网址(操作页面)有区别,所以用特定的关键字表示接口
api关键字
- https://api.baidu.com
- https://www.baidu.com/api
3)接口操作的数据称之为 资源,在url中只体现 资源 名称(名词),不体现操作资源的方式动词
常规资源接口
- https://api.baidu.com/books/
- https://api.baidu.com/books/(pk)/
非常规接口 - 和某资源不是特别密切或是不止一种资源
- https://api.baidu.com/login/
- https://api.baidu.com/place/search/
4)如果一个资源存在多版本结果,在url链接中要用特定符号来兼容多版本共存
v1|v2
- https://api.baidu.com/v1/books/
- https://api.baidu.com/v2/books/
5)群资源操作,一般还有额外的限制条件,如排序、限制调试、分页等等
?限制条件
- https://api.baidu.com/v1/books/?ordering=-price&limit=3
请求方式
6)五大请求方式
get:获取单个或多个资源
- https://api.baidu.com/books/
群查,返回多个结果对象
- https://api.baidu.com/books/(pk)/
单查,返回单个结果对象
post:新增单个或多个资源
- https://api.baidu.com/books/
单增,提交单个数据字典,完成单增,返回单个结果对象
群增,提供多个数据字典的数组,完成群增,返回多个结果对象
put:整体修改单个或多个资源
- https://api.baidu.com/books/
整体修改多个,提供多个数据字典的数组(数据字典中要包含主键),完成群改,返回多个结果对象
- https://api.baidu.com/books/(pk)/
整体修改单个,提供单个数据字典(主键在url中体现),完成单改,返回单个结果对象
patch:局部修改单个或多个资源
方式与put完全相同,不同的是:操作的资源如果有5个key-value键值对,put请求提供的字典必须全包含,但是patch提供的字典包含的键值对0~5个都可以
delete:删除单个或多个资源
- https://api.baidu.com/books/
多删,提供多个资源主键数据,完成群删,不做任何资源返回(一般我们会返回结果信息:成功|失败)
- https://api.baidu.com/books/(pk)/
单删,不需要提供额外数据,完成单删,不做任何资源返回(一般我们会返回结果信息:成功|失败)
响应结果:
7)响应对象中要包含网络状态码(网络状态信息和网络状态码捆绑出现,不要额外设置):
1xx:基本信息
2xx:成功 - 200基本 201新增成功
3xx:重定向
4xx:客户端错误 - 400错误请求;403请求无权限;404请求资源不存在
5xx:服务端错误 - 500服务器错误
8)数据状态码(一般都是前后台约定规则):
0:成功
1:失败 - 1xx:具体失败信息(要在接口文档中明确写出)
2:无数据 - 2xx:具体无数据信息(要在接口文档中明确写出)
9)数据状态信息(一般不仅仅是对数据状态码的解释,更多是对结果的描述,给前台开发者阅读的)
10)数据结果(常量、数组、字典),如果有子资源(图片、音频、视频),返回资源的url链接
{
"status": 0,
"msg": 'ok',
"results": [{
"name": "西游记",
"img": "https://api.baidu.com/media/book/xyj.png"
}]
}
"""
规范下的接口
url('^book/$') -->BookView
url('^books/?p
BookView要实现五大方法,十个逻辑
def get(self, request,*args, **kwargs):
pk=kwargs.get('pk')
if pk:
# 单查
else:
群查