导入drf_Django-drf-简单封装响应对象

该博客介绍了如何在Django REST框架中创建一个简单的Book模型,并配置URL路由和视图。使用了APIView和Serializer进行数据处理,同时展示了如何自定义响应对象。此外,还详细讲解了如何修改响应的样式,包括全局和局部配置响应渲染类,以达到仅返回JSON格式的响应。最后,讨论了修改响应配置HTML样式的意义,强调了定制化响应对于API开发者的重要性。
摘要由CSDN通过智能技术生成

c41fd963ba09631b3b1160a4a51b4b00.png

Ⅰ 基于前文封装一个简单的响应对象

models.py表模型

from django.db import models

# Create your models here.

class Book(models.Model):
    id = models.AutoField(primary_key=True)
    title = models.CharField(max_length=32)
    publish = models.CharField(max_length=32,null=True)
    price = models.DecimalField(max_digits=6,decimal_places=2,null=True)

urls.py路由

from django.urls import path,re_path
from app01 import views

urlpatterns = [
    path('books', views.Books.as_view()),
    re_path('^books/(?P<id>d+)', views.Book.as_view()),
]

views.py视图函数

  • from app01.utils import CommonResponse
from rest_framework.response import Response
from app01.serializer import BookSerializer
from app01 import models
from rest_framework.views import APIView
from app01.utils import CommonResponse

class Book(APIView):
    def put(self,request,id):
        res = CommonResponse()
        post_res = request.data
        book_res = models.Book.objects.all().filter(id=id).first()
        ser = BookSerializer(instance=book_res,data=post_res)  # instance是需要更新的对象实例
        if ser.is_valid():
            ser.save()
            res.msg = '成功'
            res.result = ['自定义数据','自定义数据']
        else:
            res.code = 404
            res.msg = '未知错误'
        return Response(res.get_dic)

serializer.py序列化器

class BookSerializer(serializers.Serializer):
    id = serializers.IntegerField(required=False, )  # required设置后表示改字段可以不传
    title = serializers.CharField(max_length=32, min_length=2, )
    price = serializers.DecimalField(max_digits=6, decimal_places=2, )
    publish = serializers.SerializerMethodField()

    def update(self, instance, validated_data):
        instance.title = validated_data.get('title')
        instance.price = validated_data.get('price')
        instance.publish = validated_data.get('publish')
        instance.save()
        return instance

tuils.py自定义封装响应对象

class CommonResponse():
    def __init__(self):
        self.code  = 200
        self.msg = ''

    @property
    def get_dic(self):
        return self.__dict__

3571fb63d86c8b3c2466b9d676071f15.png

Ⅱ 通过配置修改响应的样式

配置文件方式 -- (全局)

  • 如果没有配置,默认有浏览器和json两种样式
  • drf有默认配置文件
    • from rest_framework.settings import DEFAULTS -- 导入后,点进去,复制下面代码

2dc5474e237ddea123f8562fee5e5c99.png

我们需要在自己的配置文件中配置

项目根路径下的settings.py配置文件

# 所有drf的配置都在这个对应的字典里
REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES': (  # 默认响应渲染类
        'rest_framework.renderers.JSONRenderer',  # json渲染器
        'rest_framework.renderers.BrowsableAPIRenderer',  # 浏览API渲染器
    )
}

只保留json渲染器

  • 'rest_framework.renderers.JSONRenderer', # json渲染器

7ca7aa49dd066099402c677f8a8a18ea.png

只保留浏览器api渲染器

  • 'rest_framework.renderers.BrowsableAPIRenderer', # 浏览API渲染器

251ea76fb453b5317ae417da88563915.png

在视图类中配置 -- 局部配置

  • 力度更小,指定这个类的响应格式
  • 导入JSONRenderer,并在视图类中写renderer_classes = [JSONRenderer,]即可
from rest_framework.renderers import JSONRenderer
class Book(APIView):
    renderer_classes = [JSONRenderer,]

76178235354004b24916658f127e1e0e.png
  • 局部与全局配置冲突,以局部为准

Ⅲ 修改响应配置的html样式

改他有什么意义呢?

352efd7b1fc52dfdf793f45fe5d89fc6.png

00c9eb42d31ee6b5c04c6eb2d95d8d70.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值