DjangoRestFramework(drf实现五个接口)

安装:pip install djangorestframework

在使用drf之前,先

使用原生Django实现5个接口

models.py

python 复制代码
from django.db import models

class Book(models.Model):
    name=models.CharField(max_length=53)
    price=models.IntegerField()

views.py

python 复制代码
from app01 import models
from django.http import JsonResponse
import json
from django.views import View
class BookView(View):
    def get(self,request):
        book_list=models.Book.objects.all()
        l=[]
        for book in book_list:
            l.append({'name':book.name,'price':book.price})
        return JsonResponse({'code':100,'msg':'ok','results':l})

    def post(self,request):
        data=json.loads(request.body)
        book=models.Book.objects.create(**data)
        return JsonResponse({'code':100,'msg':'ok','results':{'name':book.name,'price':book.price}})

class BookDetailView(View):
    def get(self,request,pk):
        book=models.Book.objects.filter(pk=pk).first()
        return JsonResponse({'code':100,'msg':'ok','results':{'name':book.name,'price':book.price}})

    def delete(self,request,pk):
        models.Book.objects.filter(pk=pk).delete()
        return JsonResponse({'code':100,'msg':'ok'})

    def put(self,request,pk):
        data=json.loads(request.body)
        print(data)
        book=models.Book.objects.filter(pk=pk).first()
        book.name=data.get('name')
        book.price=data.get('price')
        book.save()
        return JsonResponse({'code':100,'msg':'ok','result':{'name':book.name,'price':book.price}})

urls.py

python 复制代码
from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
    path('admin/', admin.site.urls),
    path('books/',views.BookView.as_view()),
    path('books/<int:pk>',views.BookDetailView.as_view()),
]

以上是Django实现的5个接口,在用drf实现5个接口之前,先介绍下序列化类

序列化类介绍

在前后端分离开发中,对于RESTfulAPI设置,我们一般需要将查询/更新数据以JSON方式进行返回,而Django本身所带的ORM,仅仅支持数据的查询,并不能将查询得到的数据转换为JSON/Python的字典易读格式,而DRF为我们提供了方便的序列化器自定义类,可以通过定义序列化类,方便的返回我们所需要的数据。

序列化类可以做什么?

序列化:ORM查询结果/对象 ---> 转换为Python原生数据类型/其他可读类型(如字典或列表)---> 便于转换JSON/其他传输格式

反序列化:请求数据(通常为JSON) -> Python可读取数据结构,对象/字典,校验数据是否合法,

前端传入数据,存到数据库中。

序列化类的使用

DRF的序列化器,位于以下位置

from rest_framework import serializers

使用步骤:

1.写个py文件,叫serializer.py

2.写个类,继承serializers.Serializer

3.在类中写要序列化的字段

class PublishSerializer(serializers.Serializer):

写字段,要序列化的字段

name = serializers.CharField()

addr = serializers.CharField()

id = serializers.IntegerField()

4.在视图类中使用,完成 序列化

-多条

-ser = PublishSerializer(instance=publish_list, many=True)

-ser.data 序列化后的数据

-单条:

-ser = PublishSerializer(instance=publish)

-ser.data 序列化后的数据

使用drf实现5个接口

models.py

python 复制代码
from django.db import models

class Books(models.Model):
    name=models.CharField(max_length=43)
    price=models.IntegerField()

serializer.py

python 复制代码
from rest_framework import serializers
from app01 import models

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

views.py

python 复制代码
from app01 import models
from app01.serializer import BookSerializer
from rest_framework.viewsets import ModelViewSet
class BookView(ModelViewSet):
    queryset = models.Books.objects.all()
    serializer_class = BookSerializer

urls.py

python 复制代码
from app01 import views
from rest_framework.routers import SimpleRouter
router = SimpleRouter()
router.register('books', views.BookView, 'books')
urlpatterns = [
]
urlpatterns += router.urls
相关推荐
l1t3 分钟前
在linux和windows中解决duckdb 1.6dev版本输出执行计划报错问题
linux·运维·数据库·windows·duckdb
执子手 吹散苍茫茫烟波15 分钟前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql
tryCbest20 分钟前
Python 文件操作
服务器·python
涛声依旧-底层原理研究所41 分钟前
Agent 长任务可靠性设计:实现暂停、恢复、续跑与崩溃重启的完整方案
人工智能·python·系统架构
AC赳赳老秦1 小时前
防火墙规则批量配置实战:OpenClaw 自动生成模板、批量下发与合规性校验全解析
java·开发语言·人工智能·python·github·php·openclaw
落叶-IT1 小时前
Java异常处理深度实战教程:异常传播的失败场景分析
数据库·oracle
小小编程路1 小时前
如何优化while循环的性能?
python
卷无止境1 小时前
C++ 存储类说明符(Storage Class Specifier)大横评
c++·后端
用户019027581611 小时前
量化数据的 batch 接口有多好用?从 1 只到 500 只,批量拉数据的正确姿势
后端
rruining2 小时前
Java设计模式——结构型
后端