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
相关推荐
Cache技术分享1 分钟前
279. Java Stream API - Stream 拼接的两种方式:concat() vs flatMap()
前端·后端
2401_841495643 分钟前
【Python高级编程】2026 丙午马年元旦祝福程序
python·动画·tkinter·程序·pyinstaller·元旦·turtle
Miss_Chenzr4 分钟前
Springboot快递信息管理52c05本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
该醒醒了~4 分钟前
使用auto-py-to-exe打包python程序exe并添加图标和ico文件
python
纯粹的热爱4 分钟前
Rust 安装加速指南
后端
醉卧考场君莫笑5 分钟前
数据分析理论基础
java·数据库·数据分析
idealzouhu6 分钟前
【Android】深入浅出 JNI
android·开发语言·python·jni
南昌彭于晏11 分钟前
解决springboot静态内部类非空校验无效的问题
java·spring boot·后端
czlczl2002092512 分钟前
MybatisPlusInterceptor实现无感修改SQL的底层原理(源码)
数据库·spring boot·后端·sql
yumgpkpm14 分钟前
银行的数据智能平台和Cloudera CDP 7.3(CMP 7.3)的技术对接
数据库·人工智能·hive·hadoop·elasticsearch·数据挖掘·kafka