Django REST Framework(DRF)教程:快速入门
我們將創(chuàng)建一個(gè)簡(jiǎn)單的允許管理員用戶查看和編輯系統(tǒng)中的用戶和組的API。
項(xiàng)目設(shè)置
創(chuàng)建一個(gè)名為 tutorial 的新django項(xiàng)目,然后啟動(dòng)一個(gè)名為 quickstart 的新app。
# 創(chuàng)建項(xiàng)目目錄mkdir tutorial cd tutorial# 創(chuàng)建一個(gè)virtualenv來(lái)隔離我們本地的包依賴關(guān)系virtualenv env source env/bin/activate # 在Windows下使用 `env\Scripts\activate`# 在創(chuàng)建的虛擬環(huán)境中安裝 Django 和 Django REST frameworkpip install django pip install djangorestframework# 創(chuàng)建一個(gè)新項(xiàng)目和一個(gè)單個(gè)應(yīng)用django-admin.py startproject tutorial . # 注意結(jié)尾的'.'符號(hào)cd tutorial django-admin.py startapp quickstart cd ..現(xiàn)在第一次同步你的數(shù)據(jù)庫(kù):
python manage.py migrate我們還要?jiǎng)?chuàng)建一個(gè)名為 admin 的初始用戶,密碼為 password123。我們稍后將在該示例中驗(yàn)證該用戶。
python manage.py createsuperuser等你建立好一個(gè)數(shù)據(jù)庫(kù)和初始用戶,并準(zhǔn)備好開(kāi)始。打開(kāi)應(yīng)用程序的目錄,我們就要開(kāi)始編碼了…
Serializers
首先我們要定義一些序列化程序。我們創(chuàng)建一個(gè)名為 tutorial/quickstart/serializers.py的文件,來(lái)用作我們的數(shù)據(jù)表示。
from django.contrib.auth.models import User, Group from rest_framework import serializersclass UserSerializer(serializers.HyperlinkedModelSerializer):class Meta:model = Userfields = ('url', 'username', 'email', 'groups')class GroupSerializer(serializers.HyperlinkedModelSerializer):class Meta:model = Groupfields = ('url', 'name')請(qǐng)注意,在這個(gè)例子中我們用到了超鏈接關(guān)系,使用 HyperlinkedModelSerializer。你還可以使用主鍵和各種其他關(guān)系,但超鏈接是好的RESTful設(shè)計(jì)。
Views
好了,我們接下來(lái)再寫(xiě)一些視圖。打開(kāi) tutorial/quickstart/views.py 文件開(kāi)始寫(xiě)代碼了。
from django.contrib.auth.models import User, Group from rest_framework import viewsets from tutorial.quickstart.serializers import UserSerializer, GroupSerializerclass UserViewSet(viewsets.ModelViewSet):"""允許用戶查看或編輯的API路徑。"""queryset = User.objects.all().order_by('-date_joined')serializer_class = UserSerializerclass GroupViewSet(viewsets.ModelViewSet):"""允許組查看或編輯的API路徑。"""queryset = Group.objects.all()serializer_class = GroupSerializer不再寫(xiě)多個(gè)視圖,我們將所有常見(jiàn)行為分組寫(xiě)到叫 ViewSets 的類中。
如果我們需要,我們可以輕松地將這些細(xì)節(jié)分解為單個(gè)視圖,但是使用viewsets可以使視圖邏輯組織良好,并且非常簡(jiǎn)潔。
URLs
好的,現(xiàn)在我們?cè)趖utorial/urls.py中開(kāi)始寫(xiě)連接API的URLs。
from django.conf.urls import url, include from rest_framework import routers from tutorial.quickstart import viewsrouter = routers.DefaultRouter() router.register(r'users', views.UserViewSet) router.register(r'groups', views.GroupViewSet)# 使用自動(dòng)URL路由連接我們的API。 # 另外,我們還包括支持瀏覽器瀏覽API的登錄URL。 urlpatterns = [url(r'^', include(router.urls)),url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework')) ]因?yàn)槲覀兪褂玫氖莢iewsets而不是views,所以我們可以通過(guò)簡(jiǎn)單地使用路由器類注冊(cè)視圖來(lái)自動(dòng)生成API的URL conf。
再次,如果我們需要對(duì)API URL進(jìn)行更多的控制,我們可以簡(jiǎn)單地將其拉出來(lái)使用常規(guī)基于類的視圖,并明確地編寫(xiě)URL conf。
最后,我們將包括用于支持瀏覽器瀏覽的API的默認(rèn)登錄和注銷視圖。這是可選的,但如果您的API需要身份驗(yàn)證,并且你想要使用支持瀏覽器瀏覽的API,那么它們很有用。
Settings
我們也想設(shè)置一些全局設(shè)置。我們想打開(kāi)分頁(yè),我們希望我們的API只能由管理員使用。設(shè)置模塊都在 tutorial/settings.py 中。
INSTALLED_APPS = (...'rest_framework', )REST_FRAMEWORK = {'DEFAULT_PERMISSION_CLASSES': ['rest_framework.permissions.IsAdminUser',],'PAGE_SIZE': 10 }好了,我們完成了。
測(cè)試我們的API
我們現(xiàn)在可以測(cè)試我們構(gòu)建的API。我們從命令行啟動(dòng)服務(wù)器。
python manage.py runserver我們現(xiàn)在可以從命令行訪問(wèn)我們的API,使用諸如 curl …
bash: curl -H 'Accept: application/json; indent=4' -u admin:password123 http://127.0.0.1:8000/users/ {"count": 2,"next": null,"previous": null,"results": [{"email": "admin@example.com","groups": [],"url": "http://127.0.0.1:8000/users/1/","username": "admin"},{"email": "tom@example.com","groups": [ ],"url": "http://127.0.0.1:8000/users/2/","username": "tom"}] }或者使用 httpie,命令行工具…
bash: http -a admin:password123 http://127.0.0.1:8000/users/HTTP/1.1 200 OK ... {"count": 2,"next": null,"previous": null,"results": [{"email": "admin@example.com","groups": [],"url": "http://localhost:8000/users/1/","username": "paul"},{"email": "tom@example.com","groups": [ ],"url": "http://127.0.0.1:8000/users/2/","username": "tom"}] }或直接通過(guò)瀏覽器,轉(zhuǎn)到URL http://127.0.0.1:8000/users/…
如果您正在使用瀏覽器,請(qǐng)確保使用右上角進(jìn)行登錄。
非常棒!就是這么簡(jiǎn)單!
參考鏈接:https://www.django.cn/course/show-20.html
總結(jié)
以上是生活随笔為你收集整理的Django REST Framework(DRF)教程:快速入门的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python django设置中文及时区
- 下一篇: 【完整示例】采用jenkins pipe