Python drf day02

restful规范

restful规范是什么,如何来的?

是一种定义Web API接口的设计风格,尤其适用于前后端分离的应用模式中的规范

Roy Fielding的博士论文提出的

restful规范的具体内容

1. 数据的安全保障

--》url链接一般都采用https协议进行传输,它比http 安全

2. 接口特征表现

--》url中带api标识

  -https://api.baidu.com/books/
  -https://www.baidu.com/api/books/

3. 多数据版本共存

--》url中带版本信息

  https://api.baidu.com/v1/books
  https://www.baidu.com/api/v2/books

4. 数据即是资源,均使用名词(可复数)

---》前后端交互,交互的数据称之为资源

  数据即资源,前后端交互的数据称之为资源,url尽量使用名字

  -https://127.0.0.1/api/v1/books/ -->表示对图书操作:增加,删除,查询,修改,都用这一个地址
  -https://127.0.0.1/api/v1/get_all_books/    不符合restful规范
  -https://127.0.0.1/api/v1/delete_books/     不符合restful规范

5. 资源操作由请求方式决定

  get  请求获取数据(获取所有、获取单条)

  post  新增数据

  put  修改数据

  delete  删除数据

  https://api.baidu.com/books - get请求:获取所有书
  https://api.baidu.com/books/1 - get请求:获取主键为1的书
  https://api.baidu.com/books - post请求:新增一本书书
  https://api.baidu.com/books/1 - put请求:整体修改主键为1的书
  https://api.baidu.com/books/1 - delete请求:删除主键为1的书

6. 请求地址中带过滤条件

----》只针对搜索所有接口

 

7. 响应状态码(两层)

http响应状态码:1xx、2xx、3xx、4xx、5xx

  趣味图解HTTP状态码的含义:https://www.sohu.com/a/278045231_120014184
  -404和403 和 405
  -301和302
  -1xx表示请求正在处理---》前端一般看不到
  -2xx 表示请求处理成功--》经常看到
  -201和200有什么区别
  -3xx:重定向
  -4xx:客户端错误
  -5xx:服务端出错

成功都返回200,而在响应体中带状态码----》code:不同公司就不一样

{
"code": 101,
"msg": "用户名或密码错误"
}

-补充一:mysql 错误操作都会有个 数字(10060) 文字解释
-补充二:
-https://open.weibo.com/wiki/Error_code

8. 响应中带错误信息

{
"code": 101,
"msg": "用户名或密码错误"
}

9. 不同操作,返回格式符合如下标准

GET/collection:返回资源对象的列表(数组)

  [{name:西游记,price:19},{name:三国,price:19}]

GET/collection/resource:返回单个资源对象

  {name:三国,price:19}

POST/collection:返回新生成的资源对象

  {name:三国,price:19}

PUT/collection/resource:返回完整的资源对象

  {name:三国演义,price:19}

DELETE/collection/resource:返回一个空文档

 

---》大家都这么做

{
code:100
msg:查询成功
restult:[{name:西游记,price:19},{name:三国,price:19}]
}

10. 响应中带链接

 

序列化和反序列化

序列化:数据转换格式

序列化分两个阶段:

  序列化:把我们识别的数据转换成指定的格式提供给别人

    eg:我们在django中获取到的数据默认是模型对象,但是模型对象数据无法直接提供给前端或别的平台使用,所以我们需要把数据进行序列化,变成字符串或者json数据,提供给别人

  反序列化:把别人提供的数据转换/还原成我们需要的数据

    eg:前端js提供过来的json数据,对于python而言就是字符串,我们需要进行反序列化换成模型类对象,这样我们才能把数据保存到数据库中

drf安装和快速使用

基于Django编写符合restful规范的接口

假设已Book表为例,写他的5个接口

  -1 查询所有
  -2 新增一条
  -3 修改一条
  -4 删除一条
  -5 查询一条

使用原生Django编写

 

class BookView(View):
    # 查看全部
    def get(self, request):
        book_obj = models.Book.objects.all()
        l = []
        for i in book_obj:
            l.append({'name': i.name, 'price': i.price})
        back_dic = {'code': 100, 'msg': '查询成功', 'result': l}

        return JsonResponse(back_dic)

    # 添加数据
    def post(self, request):
        name = request.POST.get('name')
        price = request.POST.get('price')
        models.Book.objects.create(name=name, price=price)
        back_dic = {'code': 100, 'msg': '添加成功'}
        return JsonResponse(back_dic)


class BookDetailView(View):
    # 查看一条数据
    def get(self, request, pk):
        back_dic = {'code': 100, 'msg': '查询成功', 'result': []}
        book_obj = models.Book.objects.filter(pk=pk).first()
        back_dic['result'] = [{'name': book_obj.name, 'price': book_obj.price}]
        return JsonResponse(back_dic)

    # 修改一条数据
    def put(self, request, pk):
        data_dic = json.loads(request.body)
        name = data_dic.get('name')
        price = data_dic.get('price')
        back_dic = {'code': 100, 'msg': '修改成功', 'result': []}
        models.Book.objects.filter(pk=pk).update(name=name, price=price)
        back_dic['result'] = [{'name': name, 'price': price}]
        return JsonResponse(back_dic)

    # 删除一条数据

    def delete(self, request, pk):
        models.Book.objects.filter(pk=pk).delete()
        back_dic = {'code': 100, 'msg': '删除成功'}
        return JsonResponse(back_dic)

使用drf版本

# 先安装djangorestframework模块3.14.0版本

'''在app中注册
        INSTALLED_APPS = [
            'rest_framework',  # 一定不要忘了加  ,
        ]
'''
# 写路由
from rest_framework.routers import DefaultRouter

router = DefaultRouter()
router.register('book', views.BookView, 'book')

urlpatterns += router.urls

# 写视图类
from rest_framework.viewsets import ModelViewSet
from app01.serializer import BookSerializer

class BookView(ModelViewSet):
    queryset = models.Book.objects.all()
    serializer_class = BookSerializer

# 写序列化类
from rest_framework import serializers
from app01.models import Book


class BookSerializer(serializers.ModelSerializer):
    class Meta():
        model = Book
        fields = '__all__'

 

posted @ 2023-08-29 21:21  吼尼尼痛  阅读(8)  评论(0编辑  收藏  举报