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学习报错记录

    1. 运行manage.py任务  makemigrations时,报错: doesn’t declare an explicit app_label and isn’t in an application in INSTALLED_APPS. 解决:在全局setting.py的 INSTALLED_APPS中 添加 app的名字,如   2. 在添加一个生…

    2023年4月10日
    00
  • [Django]用户权限学习系列之User权限基本操作指令

    针对Django 后台自带的用户管理系统,虽说感觉还可以,但是为了方便用户一些操作,特别设计自定义的用户权限管理系统. 在制作权限页面前,首先需要了解权限和用户配置权限的指令,上章讲到权限的添加,删除,查询,本章介绍用户权限的操作指令. 首先需要导入Permission, User模块: from django.contrib.auth.models imp…

    Django 2023年4月10日
    00
  • Django——XSS攻击及处理

    XSS攻击通常指的是通过利用网页开发时留下的漏洞,通过巧妙的方法注入恶意指令代码到网页,使用户加载并执行攻击者恶意制造的网页程序。 这些恶意网页程序通常是JavaScript,但实际上也可以包括Java、 VBScript、ActiveX、 Flash 或者甚至是普通的HTML。 攻击成功后,攻击者可能得到包括但不限于更高的权限(如执行一些操作)、私密网页内…

    Django 2023年4月15日
    00
  • Django-response对象

    HttpResponse的使用 HttpRequest对象由Django自动创建,HttpResponse对象则由我们手动创建。我们设计的每一个视图都需要实例化,填充和返回一个HttpResponse,也就是函数的return的值。 传递字符串 from django.http import HttpResponse response = HttpRespo…

    Django 2023年4月11日
    00
  • 快速上手基于Anaconda搭建Django环境的教程

    下面是“快速上手基于Anaconda搭建Django环境的教程”的完整攻略: 安装Anaconda 首先,需要安装Anaconda,Anaconda 是一个 Python 集成环境,包含了许多科学计算和数据分析常用的库,而且安装非常方便。 可以去 Anaconda 官网下载对应操作系统的安装包,然后双击安装,一路按照提示进行即可。 创建Anaconda虚拟环…

    Django 2023年5月16日
    00
  • django自带User管理中添加自己的字段方法

    #coding=utf-8 from django.db import models from django.contrib.auth.models import User, make_password, check_password, Group, GroupManager from django.contrib.auth.admin import Use…

    Django 2023年4月10日
    00
  • 用soaplib的django webserver

    前面写过怎么利用suds来调用webservicePython调用基于https协议的SOAP WebService,这篇讲的是如何用soaplib开发SOAP WebService(最近发现国外开源社区里把json方式的别的Web服务也叫做WebService,叫法跟Java和.Net的约定叫法不太一样,这里加上SOAP以跟json格式的WebServic…

    Django 2023年4月10日
    00
  • Django – 权限(2)- 动态显示单级权限菜单

    一、权限组件 1、上篇随笔中,我们只是设计好了权限控制的表结构,有三个模型,五张表,两个多对多关系,并且简单实现了对用户的权限控制,我们会发现那样写有一个问题,就是权限控制写死在了项目中,并且没有实现与我们的业务逻辑解耦,当其他项目要使用权限控制时,要再重复写一遍权限控制的代码,因此我们很有必要将权限控制的功能开发成一个组件(可插拔)。   组件其实就是一个…

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