什么是DRF?
DRF即Django REST framework
的缩写,官网上说:Django REST framework
是一个强大而灵活的工具包,用于构建Web API。
简单来说:通过DRF创建API后,就可以通过HTTP请求来获取、创建、更新或删除数据(CRUD)。
那么为什么要构建API呢?
在Django中,我们通过model-view-template实现了后端和前端的通信。但前端未必是用Django的template实现的,也可以用单独的前端框架(如vue)实现。这个时候就需要一种统一的方法在前后端通信。目前一种成熟的方法就是API。
那么什么是REST?
如果你对DRF是用于构建Web API的说法已经满意了,就可以跳过这段了。
那么什么是REST?
REST(即 REpresentational State Transfer)是一种风格,用于在网络上的计算机系统之间提供标准,使系统更容易相互通信。特点是无状态和分离客户端和服务器。
也就是说,当你的API遵循了这种风格时,就可以称为RESTful API。
关于如何设计出符合REST风格的API,可以参考阮一峰的《RESTful API 设计指南》
那么用DRF实现的就是RESTful API吗?其实DRF没有强制实现。
在官网的TOPIC,REST --> Hypermedia,Hateoas中有这样一段话:
首先,免责声明。“Django REST 框架”这个名字是在 2011 年初决定的,选择它只是为了确保开发人员很容易找到这个项目。在整个文档中,我们尝试使用更简单、技术上正确的术语“Web API”。
官网的一个例子
看一个官网的例子来感受一下。
创建一个简单的API,允许管理员查看和编辑系统中的用户和组。
详细的过程推荐看官网:https://www.django-rest-framework.org/tutorial/quickstart/
配置项目
首先安装drf:
pip install djangorestframework
然后创建一个Django项目并创建应用:
mkdir tutorial cd tutorial django-admin startproject tutorial . cd tutorial django-admin startapp quickstart
这里创建项目和应用的方式有点不同,按照他的这个就行。
在settings.py
中的INSTALLED_APPS
添加rest_framework:
INSTALLED_APPS = [ ... 'rest_framework', ]
同步数据库
python manage.py migrate
创建超级用户admin,密码设置为password123:
python manage.py createsuperuser --email admin@example.com --username admin
创建API
接下来就是重点,我们要创建一个序列化程序将model转换成json格式。
1.创建序列化类
在quickstart
应用下面创建serializers.py
:
from django.contrib.auth.models import User, Group from rest_framework import serializers class UserSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = User fields = ['url', 'username', 'email', 'groups'] class GroupSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = Group fields = ['url', 'name']
序列化类(Serializer)将Model转换为序列化的JSON对象。
上面构建了User和Group的序列化类。序列化类看起来和django的Form很像。
2.创建view
在quickstart/views.py
中
from django.contrib.auth.models import User, Group from rest_framework import viewsets from rest_framework import permissions from tutorial.quickstart.serializers import UserSerializer, GroupSerializer class UserViewSet(viewsets.ModelViewSet): """ API endpoint that allows users to be viewed or edited. """ queryset = User.objects.all().order_by('-date_joined') serializer_class = UserSerializer permission_classes = [permissions.IsAuthenticated] class GroupViewSet(viewsets.ModelViewSet): """ API endpoint that allows groups to be viewed or edited. """ queryset = Group.objects.all() serializer_class = GroupSerializer permission_classes = [permissions.IsAuthenticated]
我们使用了ModelViewSet来快速构建一组view。由于背后实现了很多方法,这看起来有些像魔法。
3.配置url
在tutorial/urls.py
中:
from django.urls import include, path from rest_framework import routers from tutorial.quickstart import views router = routers.DefaultRouter() router.register(r'users', views.UserViewSet) router.register(r'groups', views.GroupViewSet) # Wire up our API using automatic URL routing. # Additionally, we include login URLs for the browsable API. urlpatterns = [ path('', include(router.urls)), path('api-auth/', include('rest_framework.urls', namespace='rest_framework')) ]
因为我们使用的是ViewSet而不是view,所以我们可以通过简单地将ViewSet注册到Router来自动生成API的 URL conf。
可以发现,和Django程序相比,我们没有写template做前端的显示,而是写了序列化类提供API。前端可以分离出来,使用API来和后端通信。
(图片来自:一图看懂Django和DRF(https://zhuanlan.zhihu.com/p/53957464))
测试API:
使用浏览器访问网址:
http://127.0.0.1:8000/users/
由于设置了权限,没登陆时查看不了。点击login用管理员账号(admin,password123)登陆:
可以看到JSON格式的数据。
也可以通过httpie工具(可以用pip安装)发送http请求获取数据:
http -a admin:password123 http://127.0.0.1:8000/users/
参考
DRF官网:https://www.django-rest-framework.org/
https://www.django-rest-framework.org/topics/rest-hypermedia-hateoas/
一图看懂Django和DRF:https://zhuanlan.zhihu.com/p/53957464
一文彻底弄懂REST API:https://zhuanlan.zhihu.com/p/536437382
RESTful API 设计指南:https://www.ruanyifeng.com/blog/2014/05/restful_api.html