RESTFramework(DRF)进阶篇(APIView类)

Posted 运维-大白同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RESTFramework(DRF)进阶篇(APIView类)相关的知识,希望对你有一定的参考价值。

1. DRF序列化器:关联表显示

应用场景:

一对多:一个项目有多个应用,一个应用只能属于一个项目
多对多:一个应用部署到多台服务器,一个服务器部署多个应用


1.1 定义数据模型

class Project(models.Model):
    name = models.CharField(max_length=30)

class App(models.Model):
    name =models.CharField(max_length=30)
    Project = models.ForeignKey(Project,on_delete=models.CASCADE)  #一对多ForeignKey

class Server(models.Model):
    hostname = models.CharField(max_length=30)
    ip = models.GenericIPAddressField()
    app = models.ManyToManyField(App)   #多对多ManyToManyField

1.2 定义路由

re_path('^api/project/$', views.ProjectView.as_view()),
re_path('api/app/$',views.Appview.as_view()),
re_path('^api/server/$',views.ServerView.as_view()),


1.3 定义序列化器(serializers.py)

from  myapp_api.models import User
from myapp_api.models import Project, App, Server
from rest_framework import serializers

class  UserSerializer(serializers.ModelSerializer):
    class Meta:
        model = User
        fields = "__all__"
        extra_kwargs = 
            'name': 'max_length':2, 'required':True, #限制名字长度
            'age':'min_value':16,'max_value':100,'required':True  #限制年龄
        


class ProjectSerializer(serializers.ModelSerializer):
    class   Meta:
        model = Project
        fields = "__all__"

class AppSerializer(serializers.ModelSerializer):
    class Meta:
        model = App
        fields = "__all__"

class ServerSerializer(serializers.ModelSerializer):
    class Meta:
        model = Server
        fields = "__all__"

1.4 定义视图(views)

from  rest_framework.views  import APIView
from rest_framework.response import Response
from .serializers import UserSerializer, ProjectSerializer,AppSerializer,ServerSerializer
from myapp_api.models import User, Project, App, Server


class Appview(APIView):
    def get(self, request, id=None):
        if id:
            obj = App.objects.get(id=id)
            ser = AppSerializer(obj)
        else:
            queryset = App.objects.all()
            ser = AppSerializer(queryset, many=True)
        res = 'code': 200, 'msg': '获取成功', 'data': ser.data
        return Response(res)
    def post(self,request):
        ser = AppSerializer(data=request.data)
        ser.is_valid(raise_exception=True)
        ser.save()
        res = 'code': 200, 'msg': '创建用户成功'
        return Response(res)


class ServerView(APIView):
    def get(self, request, id=None):
        if id:
            obj = Server.objects.get(id=id)
            ser = ServerSerializer(obj)
        else:
            queryset = Server.objects.all()
            ser = ServerSerializer(queryset, many=True)
        res = 'code': 200, 'msg': '获取成功', 'data': ser.data
        return Response(res)
    def post(self,request):
        ser = ServerSerializer(data=request.data)
        ser.is_valid(raise_exception=True)
        ser.save()
        res = 'code': 200, 'msg': '创建用户成功'
        return Response(res)

1.5添加数据



project/app/server/分别可以成功添加数据

2.0 DRF 序列化器:关联表显示

序列化器返回时当前模型中的字段,如果字段时外键时,返回是外键对应id,如果想要显示外键对应的详细信息做法如下

3.0 DRF序列化器 SerializerMethodFuekd


统计该项目应用个数

DRF 序列化器: 改变序列化和反序列化的行为

4.0 Request与Response

DRF传入视图的request对象不再是Django默认的HttpRequest对象,而是基于HttpRequest类扩展后的Request类的对象,Request对象的数据是自动根据前端发送的数据同意解析数据格式
常用属性:

request.data: 返回post提交的数据,与request.post类似
request.query_params:返回GET URL 参数,与request.GET类似

以上是关于RESTFramework(DRF)进阶篇(APIView类)的主要内容,如果未能解决你的问题,请参考以下文章

RESTFramework(DRF)进阶篇GenericAPIview-ViewSet类

RESTFramework(DRF)进阶篇GenericAPIview-ViewSet类

RESTFramework(DRF)框架初探以及认识serializers序列化器的增删改查

RESTFramework(DRF)框架初探以及认识serializers序列化器的增删改查

drf视图

DRF路由组件