一.前后端开发模式
1.前后端混合
使用模板语法渲染模板,即:后端开发 需要在前端写好的html页面 套用模板语法
2.前后端分离
后端开发只需要写API接口,使用接口测试工具(postman)测试
前端人员只需要写前端,使用mock数据完成页面测试
最终:前后端联调项目
二:API接口
1.定义:
通过网络,规定了前后台信息交互规则的url链接,也就是前后台信息交互的 媒介
2.API接口的样子
https://api.map.baidu.com/place/v2/search
-请求方式:get、post、put、patch、delete
采用get方式请求上方接口
-请求参数:json或xml格式的key-value类型数据
ak:6E823f587c95f0148c19993539b99295
region:上海
query:肯德基
output:json
响应结果:json或xml格式的数据
-响应结果:json或xml格式的数据
三:接口测试工具postman
1.下载及安装
官网:https://www.postman.com/downloads/
下载后直接双击安装即可
四:restful规范
1.来源:
REST全称是Representational State Transfer,中文意思是表述:表征性状态转移, 它首次出现在2000年Roy Fielding的博士论文中
2.定义:
RESTful是一种定义Web API接口的设计风格,尤其适用于前后端分离的应用模式中
3.restful规范
-
1.数据安全保障:url链接一般都采用https协议进行传输(https是什么?http+ssl/tsl) -
2.接口中带api关键字(域名中或者url中) -
3.多数据版本共存,一个接口可能有多个版本,url链接中表示版本标识 -
4.数据即是资源,均使用名词(可以复数),接口尽量使用名词 -
5.资源操作由请求方式决定
- 获取数据:get
- 删除数据:delete
- 新增数据:post
- 修改数据:put, patch
-
6.url地址中带过滤参数
- 获取动物园所有动物 eg: 127.0.0.1/api/v2/animals
- 获取动物园中所有的鸟类动物:eg: 127.0.0.1/api/v1/animals?type=鸟类
-
7.响应带状态码
- http状态码大全地址: http://tools.jb51.net/table/http_status_code
- 1xx:请求正在处理,一般看不到
- 2xx:请求成功
- 3xx:重定向
- 4xx:客户端错误
- 5xx:服务端错误
-
公司中一般都有自己的规范,在响应体中写状态码:{code: 100, msg:成功} -
8.返回错误信息 -
响应体中带错误信息:{code: 404, msg: 资源不存在} -
9.返回结果:针对不同操作,服务器向用户返回的结果应该符合以下规范 -
GET /collection:返回资源对象的列表(数组)[{},{}]
GET /collection/resource:返回单个资源对象 {}
POST /collection:返回新生成的资源对象 {}
PUT /collection/resource:返回完整的资源对象 {}
PATCH /collection/resource:返回完整的资源对象 {}
DELETE /collection/resource:返回一个空文档
-获取所有:{code:100,msg:成功,data:[{name:金瓶梅,price:99},{name:西游 记,price:88}]}
-获取单条:{code:100,msg:成功,data:{name:金瓶梅,price:99}}
-新增数据:{code:100,msg:新增成功,data:{name:西游记,price:99}}
-修改数据:{code:100,msg:修改成功,data:{name:西游记v2版本,price:99}}
-删除数据:{code:100,msg:删除成功}
五:序列化和反序列化
1.序列化
把我们能够识别的数据格式 转换成 指定的数据格式提供给别人
例如:django中获取到的数据格式默认是:模型对象(queryset), 通过序列化把数据变成json格式的数据,提供给前端
2.反序列化
把别人提供的数据格式转换成 我们需要的(能够识别的)数据格式
六:djangorestframework的快速上手使用
1.功能:
方便写出符合restful规范的接口
2.接口:
get 获取所有
get 获取单个
post 新增一条
put/patch 修改一条
delete 删除一条
七:快速实现5个接口
urls.py
from django.contrib import admin
from django.urls import path
from rest_framework.routers import SimpleRouter
from app01 import Views
router = SimpleRouter()
router.register('books', views.BookView)
urlpatterns = [
path('books/', admin.site.urls),
]
views.py
from .models import Book
from rest_framework.viewsets import ModelViewSet
from .serializer import BookSerializer
class BookView(ModelViewSet):
queryset = Book.objects.all()
serializer_class = BookSerializer
models.py
from django.db import models
class Book(models.Model):
name = models.CharField(max_length=32)
price = models.CharField(max_length=32)
publish = models.CharField(max_length=32)
serializer.py
from rest_framework import serializers
from .models import Book
class BookSerializer(serializers.ModelSerializer):
class Meta:
model = Book
fields = '__all__'
八:CBV源码分析
第一步:
path('test/', views.TestView.as_view()),
我们去我们自定义的类中去查找,发现没有as_views()这个方法
那么我们去父类view中去查找,找到了as_views()这个方法
第二步:
@classonlymethod
def as_view(cls, **initkwargs):
def view(request, *args, **kwargs):
return self.dispatch(request, *args, **kwargs)
return view
第三步:
def dispatch(self, request, *args, **kwargs):
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(),self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)
|