一:restful规范
restful是一个规范,面向资源架构,总共有十条规范:
1:API与用户的通信协议,总是使用HTTPS协议
2:域名
https://api.example.com 尽量将API不熟在专用域名(会存在跨域问题,不推荐使用)
https://example.org/api/ API很简单(推荐)
3:版本
https://api.example.com/v1/ 把版本号放在请求头中
4:路径,将网络上任何东西都看作资源,都使用名词表示(可复数)
127.0.0.1/get_all_book/ 旧版本
127.0.0.1/books/ (可用名词,也可以用复数)
5:method,通过请求方式来表示进行的操作(get请求,post请求,delete请求,put、patch请求)
127.0.0.1/books/ get请求:表示获取所有图书
127.0.0.1/books/1 get请求:表示获取id为1的图书
127.0.0.1/books/ post请求:表示新增一本书
127.0.0.1/books/ delete请求:表示删除一本书
127.0.0.1/books/ put/patch请求:表示修改一本书
6:过滤,通过在url上传参的形式传递搜索条件
7:状态码
1 开头:服务器正在处理
2 开头:服务器处理成功
3 开头:重定向
4 开头:客户端错误
5 开头:服务器错误
8:错误处理,应返回错误信息,error当做key
9:返回结果,针对不同操作,服务器向用户返回的结果应该符合以下规范
10:返回结果中提供链接
二:cbv执行流程(class base view)
路由写成:url(r'books/',views.Book.as_view())
当程序启动,第二个位置其实已经放了一个函数的内存地址了(as_view内部view这个函数)
比如来了一个get请求,拿到第二个位置参数内存地址加括号执行(request,*args,**kwargs),其实就是view(request,*args,**kwargs)
dispatch方法内部通过请求方式(get,post),反射出要执行的方法,去执行,然后返回
三:drf框架安装和简单使用(Djangorestframework)(其实就是一个app)
只要用drf,以后写的都是cbv。(就是在原来Django框架的基础上多做了一些事)
安装方法:方式一:pip3 install djangorestframework
方式二:pycharm图形化界面安装
方式三:pycharm命令行下安装(装在当前工程所用的解释器下)
drf提供的:序列化组件、视图组件、解析器、认证组件、权限组件、频率组件、分页器、响应器、url控制器、版本控制
四:APIView的源码执行流程
-比如get请求来了,执行View的as_view方法内部的view闭包函数,view闭包函数中执行了dispatch方法,
-现在再执行dispatch,就已经不是View的dispatch,是APIView的dispatch方法了