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

yizhihongxing

下面是针对“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中itsdangerous的用法

     itsdangerous用来解决什么问题,为什么需要用到itsdangerous? 安装命令:pip install itsdangerous 有时候你想向不可信的环境发送一些数据,但如何安全完成这个任务呢?解决的方法就是签名。使用只有你自己知道的密钥,来加密签名你的数据,并把加密后的数据发给别人。当你取回数据时,你就可以确保没人篡改过这份数据。 诚然,接…

    Django 2023年4月10日
    00
  • Django 构建模板form表单的两种方法

    下面我将详细讲解Django构建模板form表单的两种方法,并提供两个示例。 方法一:使用Django模板默认的form表单 Django模板默认提供了form表单的渲染,方便我们快速地渲染出一个表单。 使用此方法时,需要在视图函数中定义一个form变量,并为其赋值为一个forms.Form对象(也可以是子类或其他表单类)。然后在模板中,使用form.as_…

    Django 2023年5月16日
    00
  • django的form常用字段和参数

    Django 的内置字段 Field required=True#请求不能为空 widget=None#HTML插件 label=None#用于生成lable标签或显示内容 initial=None#初始值 help_text=”#帮助信息(在标签旁边显示) error_messages=None#(错误信息{‘required’:’不能为空’,‘inva…

    Django 2023年4月13日
    00
  • django中使用sha1,md5加密

    # salt 盐 使用sha1加密算法,返回str加密后的字符串 # 提高字符串的复杂的 from hashlib import sha1 def get_hash(str, salt=None): # salt 盐 ”’取一个字符串的hash值”’ # 提高字符串的复杂度 str = ‘!@#$%’+str+’&^**(‘ if salt: s…

    Django 2023年4月10日
    00
  • Django admin组件的使用

    Django是一个非常流行的Python Web开发框架。它自带了一个非常强大的组件,称为Django admin。这个组件很容易使用,使得在无需编写控制面板代码的情况下,你就可以创建一个功能强大的控制面板。在本文中,我将详细讲解如何使用Django admin组件。 第一步:创建Django项目 首先,我们需要在本地机器上创建一个Django项目。使用以下…

    Django 2023年5月16日
    00
  • Python Django 开发 3 数据库CURD

    上一篇表建好后开始对数据进行CURD操作 dos输入: >>>python manage.py shell 以下的命令都是在shell中测试 (C)增: 1 >>>import myLesson import Blog 2 >>>b = Blog(name = ‘Frist Blog’, tagline …

    Django 2023年4月16日
    00
  • 使用Django连接Mysql数据库步骤

    当使用Django时,连接Mysql数据库的步骤可以分为以下几步: 步骤1:安装Mysql数据库驱动 在连接Mysql数据库之前,需要确保已经安装了Mysql数据库驱动。常用的Mysql数据库驱动有mysqlclient和PyMySQL,可以根据自己的需要选择其中一种安装。在本示例中,我们将使用mysqlclient。 安装mysqlclient可以使用pi…

    Django 2023年5月16日
    00
  • Django多数据库联用实现方法解析

    Django是一个流行的Python Web框架,可以让我们快速开发Web应用程序。在一些大型的Web应用程序中,我们可能需要同时使用多个数据库。本文将讲解Django如何实现多数据库联用。本文包括以下内容: Django多数据库联用的基本原理 Django如何配置多个数据库 示例一:在Django中使用一个默认数据库和一个只读从属数据库 示例二:在Djan…

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