Django REST framework 介绍

目录

Django REST framework 介绍

Django REST framework框架是一个用于构建 Web API 的强大而又灵活的工具. 通常简称为DRF框架 或 REST framework框架.

特点

  • 提供了定义序列化器 serializer 的方法,可以快速根据 Django ORM 或者其他库自动序列化/反序列化;
  • 提供了丰富的类视图、Mixin扩展类、简化视图的编写;
  • 丰富的定制层级: 函数视图、类视图、视图集合到自动生成API,满足各种需求;
  • 多种身份认证和权限认证方式的支持;
  • 内置了限流系统;
  • 直观的API web界面;
  • 可扩展性, 插件丰富

官方文档

https://www.django-rest-framework.org/

源码地址

https://github.com/encode/django-rest-framework/tree/master

DRF 框架的安装

1 安装:换 pip 源

pip install djangorestframework

2 配置:在 settings 中注册

INSTALLED_APPS = [
 # ...
 'rest_framework',
]

3 在 settings 中自定义drf配置

注:drf 配置查找顺序,自定义 settings 的 REST_FRAMEWORK 配置字典 => drf 默认 settings 的DEFAULTS
REST_FRAMEWORK = {}

4 drf 的封装特点:特点功能在特点模块下

from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.request import Request

示例

"""
1)在models.py创建Model类
from django.db import models
class Book(models.Model):
 name = models.CharField(max_length=64, verbose_name='书名')
 price = models.DecimalField(max_digits=5, decimal_places=2, verbose_name='价格')

 # 配置类
 class Meta:
     verbose_name_plural = '图书'

 def __str__(self):
     return self.name
     
2)在admin.py中注册Model类,方便在后台(admin)可视化管理数据
from django.contrib import admin
from . import models
admin.site.register(models.Book)  # admin要控制的model都需要注册一下

3)数据库迁移操作
>: python manage.py makemigrations
>: python manage.py migrate
>: python manage.py createsuperuser
  admin | Admin123
  
4)浏览器登录admin录入数据:http://localhost:8000/admin
"""

基于 restful 接口规范的接口设计

urlpatterns = [
 # 资源books接口的设计
 url(r'^books/$', views.BookAPIView.as_view()),  # 群查、单增
 url(r'^books/(?P<pk>\d+)/$', views.BookAPIView.as_view()),  # 单查、单删、单(整体|局部)改
]

实现单查群查接口

from rest_framework.views import APIView
from rest_framework.response import Response
from . import models
class BookAPIView(APIView):
 def _multiple_get(self):
     # 不能返回,数据是QuerySet[Obj, Obj],也不能强制转换list
     # return list(models.Book.objects.all())

     # QuerySet[dict, dict]
     # print(models.Book.objects.values('name', 'price'))
     # QuerySet[tuple, tuple]
     # print(models.Book.objects.values_list('name', 'price'))

     return Response(list(models.Book.objects.values('name', 'price')))

 def _single_get(self, pk):
     # return Response(models.Book.objects.filter(pk=pk).values('name', 'price').first())

     # 开发阶段建议能用try的地方,不要使用if判断
     try:
         return Response(models.Book.objects.values('name', 'price').get(pk=pk))
     except:
         return Response('资源不存在')

 # 单查、群查
 def get(self, request, *args, **kwargs):
     pk = kwargs.get('pk')
     if pk:
         # 单查逻辑
         return self._single_get(pk)
     else:
         # 群查逻辑
         return self._multiple_get()