drf之day01:前后端开发模式,API接口,postman接口测试工具,restful规范,序列化和反序列化,djangorestframework的快速实现五个接口,CBV源码分析

一.前后端开发模式

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.返回结果:针对不同操作,服务器向用户返回的结果应该符合以下规范

  •    # 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:删除成功}
    

五:序列化和反序列化

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()),

# 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)
# 这里用到了反射,如果我们自己定义的类中的方法在提前设定好的方法列表中,则会执行该方法
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值