| 一.前后端开发模式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格式的数据
 三:接口测试工具postman1.下载及安装官网: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_code1xx:请求正在处理,一般看不到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)
 |