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
相关推荐
ZhengEnCi1 分钟前
09a-斯坦福 CS336 作业一:BPE 分词器
python·神经网络
测试员周周8 分钟前
【Appium 系列】第18节-重试与容错 — 移动端测试的稳定性保障
人工智能·python·功能测试·ui·单元测试·appium·测试用例
invicinble10 分钟前
spring提供的其他机制
java·后端·spring
还是鼠鼠19 分钟前
AI掘金头条新闻系统 (Toutiao News)-用户注册-创建用户
后端·python·mysql·fastapi·web
灰灰勇闯IT28 分钟前
DeepSeek-R1 在 CANN 上的推理部署
pytorch·python·深度学习
l1t30 分钟前
Hy-MT2-1.8B总结的pgvector 0.8.2解决了并行HNSW索引构建漏洞
数据库·人工智能·postgresql
李广坤35 分钟前
别再把 Filter、Interceptor 和 AOP 混为一谈了!从接口加解密谈 Spring 纵深架构设计
后端
我是一颗柠檬41 分钟前
【MySQL全面教学】MySQL条件查询与排序Day4(2026年)
数据库·后端·mysql
丷丩42 分钟前
Postgresql基础实践教程(四)
数据库·postgresql
六月雨滴1 小时前
RMAN 增量备份(Incremental Backup)
数据库·oracle