Django rest framework基本介绍与代码示例

下面是针对“Django rest framework基本介绍与代码示例”的详细讲解:

1. Django rest framework基本介绍

Django rest framework是一个建立在Django框架上的Web API开发工具,它基于大量的RESTful原则来构建API。Django rest framework可以帮助我们快速构建高质量的Web API,它提供了许多功能,比如序列化器(Serializer), API视图(API Views), 认证(Authentication),权限控制(Permission)等。

需要使用Django rest framework的话,我们需要在Django项目中添加依赖。在终端中运行如下命令:

pip install djangorestframework

在项目的设置文件settings.py中,我们需要将rest framework添加到INSTALLED_APPS中:

INSTALLED_APPS = (
    #..其他应用
    'rest_framework',
)

2. 代码示例1:使用Serializer进行序列化

Django的ORM(Object Relational Mapper)能够使我们很方便的操作数据库,同时也支持将操作后的结果进行序列化输出,但是默认的序列化方法不可定制,不满足我们实际的需求。在这种情况下,我们可以借助Django rest framework提供的序列化框架。下面,我们来看一下使用Serializer进行序列化的示例代码。

(1)定义序列化器

首先,我们需要定义一个序列化器来描述序列化结构,序列化器需要继承Django rest framework提供的Serializer。

from rest_framework import serializers
from .models import UserInfo

class UserInfoSerializer(serializers.Serializer):
    id = serializers.IntegerField(read_only=True)
    name = serializers.CharField(required=True, max_length=30)
    age = serializers.IntegerField(required=True)
    sex = serializers.BooleanField(required=True)

    def create(self, validated_data):
        """
        用于在创建新的实例时调用
        """
        return UserInfo.objects.create(**validated_data)

    def update(self, instance, validated_data):
        """
        用于在更新实例时调用
        """
        instance.name = validated_data.get('name', instance.name)
        instance.age = validated_data.get('age', instance.age)
        instance.sex = validated_data.get('sex', instance.sex)
        instance.save()
        return instance

在定义序列化器的时候,需要为每一个序列化字段定义一个相应的Serializer类型,我们可以使用Serializer的子类可以支持自定义序列化字段的各种属性,例如是否必须存在、最大长度等。在序列化器中,我们还可以定义create()和update()方法,用来在创建和更新实例时进行调用。

(2)构建视图函数

接下来,我们需要构建一个视图函数来响应客户端请求。这里采用基于函数的视图方式。

from django.http import HttpResponse
from django.views.decorators.csrf import csrf_exempt
from rest_framework.renderers import JSONRenderer
from rest_framework.parsers import JSONParser
from .models import UserInfo
from .serializers import UserInfoSerializer

@csrf_exempt
def userinfo_list(request):
    """
    列出所有的用户信息,或者创建一个新的用户信息
    """
    if request.method == 'GET':
        userinfo = UserInfo.objects.all()
        serializer = UserInfoSerializer(userinfo, many=True)
        return JsonResponse(serializer.data, safe=False)

    elif request.method == 'POST':
        data = JSONParser().parse(request)
        serializer = UserInfoSerializer(data=data)
        if serializer.is_valid():
            serializer.save()
            return JsonResponse(serializer.data, status=201, safe=False)
        return JsonResponse(serializer.errors, status=400)

在视图函数中,我们可以根据对应的HTTP方法进行不同的响应。GET方法用于获取所有实例,POST方法用于创建新的实例。

(3)配置URL映射

最后,我们需要在urls.py中配置URL映射规则。

from django.conf.urls import url
from . import views

urlpatterns = [
    url(r'^users/$', views.userinfo_list),
]

运行程序并通过浏览器访问http://localhost:8000/users/可以看到序列化后的输出结果。

3. 代码示例2:使用Generic View进行API操作

除了使用基于函数的视图外,Django rest framework同样提供了基于类的视图。上面介绍的序列化范例实际上已经包含了基于函数的视图的使用方法。基于类的视图可以进一步简化代码量,提高代码的可维护性。下面我们来看一下使用Generic View进行API操作的示例代码。

(1)定义模型

为了实现API操作,我们需要首先定义一个模型用来存储数据。在这里,我们定义一个名为UserInfo的模型。

from django.db import models

class UserInfo(models.Model):
    name = models.CharField(max_length=30)
    age = models.IntegerField()
    sex = models.BooleanField()

(2)定义序列化器

我们可以复用上面定义的序列化器。

(3)构建视图类

接下来,我们需要定义一个视图类来操作模型。在这里,我们基于类视图,使用Django rest framework提供的generics包中的ListCreateAPIView视图来实现基本的API操作。

from .models import UserInfo
from .serializers import UserInfoSerializer
from rest_framework import generics

class UserInfoList(generics.ListCreateAPIView):
    queryset = UserInfo.objects.all()
    serializer_class = UserInfoSerializer

class UserInfoDetail(generics.RetrieveUpdateDestroyAPIView):
    queryset = UserInfo.objects.all()
    serializer_class = UserInfoSerializer

在视图类中,我们需要指定查询的数据集(queryset),以及使用到的序列化器(serializer_class)。

(4)配置URL映射

最后,在urls.py中配置URL映射规则。

from django.conf.urls import url
from . import views

urlpatterns = [
    url(r'^users/$', views.UserInfoList.as_view()),
    url(r'^users/(?P<pk>[0-9]+)/$', views.UserInfoDetail.as_view()),
]

运行程序并通过浏览器访问http://localhost:8000/users/可以看到序列化后的输出结果。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django rest framework基本介绍与代码示例 - Python技术站

(0)
上一篇 2023年5月16日
下一篇 2023年5月16日

相关文章

  • DJANGO复制记录的方法(转载)

    DJANGO复制记录的方法 https://dmyz.org/archives/326 最近的Django项目中有复制记录的需求。数据库里有一张名为Party的表,记录用户创建的party,现在要让用户能够复制一个新的party。本身非常简单的一个功能,但运行的时候出错了。我以为是复制过程出错,所以测试了一下Django中复制记录可能遇到的情况(后来发现是其…

    Django 2023年4月12日
    00
  • Django常见错误信息汇总及解决方案

    摘要:最近学习Django中,自己随便写写还是碰到了挺多问题,不过貌似都是比较常见,还能顺利解决。现在写下来,也许以后会忘记,也许能帮上碰到同样问题的 小编我前面已经写过一篇关于Django常见错误的文章了,该文比较适合新手阅读,防止学习Django过程中入坑。今天小编我要总结实际Django开发过程中和debug过程中经常碰到的错误信息以及如何解决它们。本…

    Django 2023年4月15日
    00
  • Django 创建后台,配置sqlite3教程

    下面是详细讲解Django创建后台、配置sqlite3的完整攻略。 1. 安装Django 首先,你需要安装Django。可以通过在终端或命令提示符下输入以下命令来安装: pip install Django 2. 创建Django项目 安装完成后,你可以在终端或命令提示符下输入以下命令来创建Django项目: django-admin startproje…

    Django 2023年5月16日
    00
  • django foreignkey(外键)的实现

    下面是关于 Django ForeignKey 外键的实现的完整攻略,包含两个示例说明。 什么是 Django ForeignKey 外键? 在 Django 中,ForeignKey 是一种用于定义关系的字段类型。它通常用于将一个模型与另一个模型相关联。通过 ForeignKey,我们可以在一个模型中引用另一个模型的数据。 如何定义 Django Fore…

    Django 2023年5月15日
    00
  • pycharm社区版安装django并创建一个简单项目的全过程

    下面我将详细讲解“Pycharm社区版安装Django并创建一个简单项目的全过程”: 1. 安装Pycharm社区版 首先,你需要在官网(https://www.jetbrains.com/pycharm/download/)下到Pycharm社区版的安装包,然后运行安装包进行安装。在安装时,你需要选择自己系统对应的版本,我这里安装的是Windows版本。 …

    Django 2023年5月16日
    00
  • Django 创建超级用户

    Django自带的后台管理是Django明显特色之一,可以让我们快速便捷管理数据。后台管理可以在各个app的admin.py文件中进行控制     #创建超级用户 python manage.py createsuperuser   注意密码需要8位,数字和字母组合   存储在auth_user表中   一、       基本设置   1、应用注册 若要把a…

    Django 2023年4月12日
    00
  • Django显示可视化图表的实践

    我会详细讲解“Django显示可视化图表的实践”的完整攻略,同时提供两个示例说明。 概述 Django是一款流行的Python Web框架,可以用来开发各种类型的Web应用程序。本攻略主要讲述使用Django来显示可视化图表的实践,其中包括两个示例。 环境准备 在使用Django来显示可视化图表之前,需要准备相关的环境和工具。以下是环境准备的步骤: 安装Dj…

    Django 2023年5月16日
    00
  • 解决django报错:.accepted_renderer not set on Response

    报错如图: 报错原型:视图函数继承错误: 解决:继承 rest_framework.views  里面的APIView

    Django 2023年4月12日
    00
合作推广
合作推广
分享本页
返回顶部