摘要:看起來不錯(cuò)再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫
我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個(gè)強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。
使用基于類的視圖重寫我們的API
我們將首先將根視圖重寫為基于類的視圖。所有這一切都涉及到一些重構(gòu)views.py。
from snippets.models import Snippet from snippets.serializers import SnippetSerializer from django.http import Http404 from rest_framework.views import APIView from rest_framework.response import Response from rest_framework import status class SnippetList(APIView): # APIView實(shí)際繼承django總的View # from django.views.generic import View """ # 這里是SnippetList接口描述 List all snippets, or create a new snippet. """ def get(self, request, format=None): snippets = Snippet.objects.all() # manay=True 用于querySet對(duì)象 serializer = SnippetSerializer(snippets, many=True) 3 Respone比django的response更強(qiáng)大 return Response(serializer.data) def post(self, request, format=None): serializer = SnippetSerializer(data=request.data) if serializer.is_valid(): # .save()是調(diào)用SnippetSerializer中的create()方法 serializer.save() return Response(serializer.data, status=status.HTTP_201_CREATED) return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
到現(xiàn)在為止還挺好。它看起來與以前的情況非常相似,但是我們?cè)诓煌腍TTP方法之間有更好的分離。我們還需要更新實(shí)例視圖views.py。
class SnippetDetail(APIView): """ Retrieve, update or delete a snippet instance. """ def get_object(self, pk): try: return Snippet.objects.get(pk=pk) except Snippet.DoesNotExist: raise Http404 def get(self, request, pk, format=None): snippet = self.get_object(pk) serializer = SnippetSerializer(snippet) return Response(serializer.data) def put(self, request, pk, format=None): snippet = self.get_object(pk) serializer = SnippetSerializer(snippet, data=request.data) if serializer.is_valid(): serializer.save() return Response(serializer.data) return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) def delete(self, request, pk, format=None): snippet = self.get_object(pk) snippet.delete() return Response(status=status.HTTP_204_NO_CONTENT)
看起來不錯(cuò) 再次,它現(xiàn)在仍然非常類似于基于功能的視圖。
我們還需要重構(gòu)urls.py一下我們使用基于類的視圖。
from django.conf.urls import url from rest_framework.urlpatterns import format_suffix_patterns from snippets import views urlpatterns = [ url(r"^snippets/$", views.SnippetList.as_view()), url(r"^snippets/(?P[0-9]+)/$", views.SnippetDetail.as_view()), ] urlpatterns = format_suffix_patterns(urlpatterns)
好的,我們完成了 如果運(yùn)行開發(fā)服務(wù)器,那么應(yīng)該像以前一樣工作。
使用mixins
使用基于類視圖的最大好處之一就是讓我們輕松地組合可重用的行為。
到目前為止,我們使用的創(chuàng)建/查看/更新/刪除操作與我們創(chuàng)建的任何支持模型的API視圖相似。這些常見的行為是在REST框架的mixin類中實(shí)現(xiàn)的。
我們來看看我們?nèi)绾问褂胢ixin類編寫視圖。這是我們的views.py模塊了。
from snippets.models import Snippet from snippets.serializers import SnippetSerializer from rest_framework import mixins from rest_framework import generics class SnippetList(mixins.ListModelMixin, mixins.CreateModelMixin, generics.GenericAPIView): # mixins.CreateModelMixin 可以保存數(shù)據(jù) # generics.GenericAPIView 繼承了APIView queryset = Snippet.objects.all() serializer_class = SnippetSerializer def get(self, request, *args, **kwargs): # self.list是ListModelMixin的list函數(shù) # 功能是過濾、分頁、調(diào)用serializer,將數(shù)據(jù)序列化 return self.list(request, *args, **kwargs) def post(self, request, *args, **kwargs): return self.create(request, *args, **kwargs)
我們會(huì)花一點(diǎn)時(shí)間仔細(xì)檢查這里發(fā)生的情況。我們用GenericAPIView建一個(gè)視圖,并在加ListModelMixin和CreateModelMixin。
基類提供核心功能,而mixin類提供.list()和.create()操作。我們明確綁定get和post方法。到目前為止足夠簡(jiǎn)單的東西
class SnippetDetail(mixins.RetrieveModelMixin, mixins.UpdateModelMixin, mixins.DestroyModelMixin, generics.GenericAPIView): queryset = Snippet.objects.all() serializer_class = SnippetSerializer def get(self, request, *args, **kwargs): return self.retrieve(request, *args, **kwargs) def put(self, request, *args, **kwargs): return self.update(request, *args, **kwargs) def delete(self, request, *args, **kwargs): return self.destroy(request, *args, **kwargs)
很相似,我們?cè)偈褂玫腉enericAPIView類來提供核心功能,并增加提供.retrieve(),.update()和.destroy()方法。
使用泛型類視圖
使用mixin類,我們重寫了這些視圖,使用的代碼比以前少得多,但是我們可以進(jìn)一步。REST框架提供了一組已經(jīng)混合的通用視圖,我們可以使用它來修剪我們的views.py模塊。
from snippets.models import Snippet from snippets.serializers import SnippetSerializer from rest_framework import generics class SnippetList(generics.ListCreateAPIView): queryset = Snippet.objects.all() serializer_class = SnippetSerializer class SnippetDetail(generics.RetrieveUpdateDestroyAPIView): queryset = Snippet.objects.all() serializer_class = SnippetSerializer
哇,這很簡(jiǎn)潔。我們已經(jīng)免費(fèi)獲得了大量的數(shù)據(jù),而且我們的代碼看起來很好,干凈,慣用的Django。
接下來,我們將介紹本教程的第4部分,我們將在此介紹如何處理API的身份驗(yàn)證和權(quán)限。
Django REST FrameWork中文文檔目錄:
Django REST FrameWork 中文教程1:序列化
Django REST FrameWork 中文教程2:請(qǐng)求和響應(yīng)
Django REST FrameWork 中文教程3:基于類的視圖
Django REST FrameWork 中文教程4:驗(yàn)證和權(quán)限
Django REST FrameWork 中文教程5:關(guān)系和超鏈接API
Django REST FrameWork 中文教程6: ViewSets&Routers
Django REST FrameWork 中文教程7:模式和客戶端庫
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/45455.html
摘要:看起來不錯(cuò)再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個(gè)強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。 使用基于類的...
摘要:看起來不錯(cuò)再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個(gè)強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。 使用基于類的...
摘要:請(qǐng)注意,我們不再明確地將我們的請(qǐng)求或響應(yīng)明確綁定到給定的內(nèi)容類型。這允許返回完全可瀏覽網(wǎng)頁的表示。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 從這一點(diǎn)開始,我們將真正開始覆蓋REST框架的核心。我們來介紹幾個(gè)基本的構(gòu)建塊。 請(qǐng)求對(duì)象REST框架引入了Request擴(kuò)展常規(guī)的對(duì)象HttpReques...
摘要:請(qǐng)注意,我們不再明確地將我們的請(qǐng)求或響應(yīng)明確綁定到給定的內(nèi)容類型。這允許返回完全可瀏覽網(wǎng)頁的表示。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 從這一點(diǎn)開始,我們將真正開始覆蓋REST框架的核心。我們來介紹幾個(gè)基本的構(gòu)建塊。 請(qǐng)求對(duì)象REST框架引入了Request擴(kuò)展常規(guī)的對(duì)象HttpReques...
摘要:請(qǐng)注意,我們不再明確地將我們的請(qǐng)求或響應(yīng)明確綁定到給定的內(nèi)容類型。這允許返回完全可瀏覽網(wǎng)頁的表示。中文文檔目錄中文教程序列化中文教程請(qǐng)求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 從這一點(diǎn)開始,我們將真正開始覆蓋REST框架的核心。我們來介紹幾個(gè)基本的構(gòu)建塊。 請(qǐng)求對(duì)象REST框架引入了Request擴(kuò)展常規(guī)的對(duì)象HttpReques...
閱讀 433·2019-08-29 12:44
閱讀 3011·2019-08-26 17:49
閱讀 2433·2019-08-26 13:40
閱讀 1185·2019-08-26 13:39
閱讀 3663·2019-08-26 11:59
閱讀 1827·2019-08-26 10:59
閱讀 2465·2019-08-23 18:33
閱讀 2697·2019-08-23 18:30