赞
踩
使用模板语法渲染模板,即:后端开发 需要在前端写好的html页面 套用模板语法
后端开发只需要写API接口,使用接口测试工具(postman)测试
前端人员只需要写前端,使用mock数据完成页面测试
最终:前后端联调项目
通过网络,规定了前后台信息交互规则的url链接,也就是前后台信息交互的 媒介
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格式的数据
官网:https://www.postman.com/downloads/
下载后直接双击安装即可
REST全称是Representational State Transfer,中文意思是表述:表征性状态转移, 它首次出现在2000年Roy Fielding的博士论文中
RESTful是一种定义Web API接口的设计风格,尤其适用于前后端分离的应用模式中
1.数据安全保障:url链接一般都采用https协议进行传输(https是什么?http+ssl/tsl)
2.接口中带api关键字(域名中或者url中)
3.多数据版本共存,一个接口可能有多个版本,url链接中表示版本标识
4.数据即是资源,均使用名词(可以复数),接口尽量使用名词
5.资源操作由请求方式决定
6.url地址中带过滤参数
7.响应带状态码
公司中一般都有自己的规范,在响应体中写状态码:{code: 100, msg:成功}
8.返回错误信息
响应体中带错误信息:{code: 404, msg: 资源不存在}
9.返回结果:针对不同操作,服务器向用户返回的结果应该符合以下规范
# restful规范
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:删除成功}
把我们能够识别的数据格式 转换成 指定的数据格式提供给别人
例如:django中获取到的数据格式默认是:模型对象(queryset), 通过序列化把数据变成json格式的数据,提供给前端
把别人提供的数据格式转换成 我们需要的(能够识别的)数据格式
方便写出符合restful规范的接口
get 获取所有
get 获取单个
post 新增一条
put/patch 修改一条
delete 删除一条
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__'
path('test/', views.TestView.as_view()),
# 1.首先从类的方法as_views()入手
我们去我们自定义的类中去查找,发现没有as_views()这个方法
那么我们去父类view中去查找,找到了as_views()这个方法
# 2.在父类view中,发现as_views()方法的返回值是view,则路由层的url变成了:view(request)
@classonlymethod
def as_view(cls, **initkwargs):
def view(request, *args, **kwargs):
return self.dispatch(request, *args, **kwargs)
return view
# 3.当请求来的时候,路由匹配成功,执行view(request),返回dispatch()方法
# 4.到我们自己定义的类中去查找,发现没有dispath()方法,则执行父类view中的dispatch方法
def dispatch(self, request, *args, **kwargs):
if request.method.lower() in self.http_method_names:
# 这里就相当于是:getattr('自定义类产生的对象','方法字符串','默认值')
handler = getattr(self, request.method.lower(),self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)
# 这里用到了反射,如果我们自己定义的类中的方法在提前设定好的方法列表中,则会执行该方法
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。