国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Django rest framework使用類視圖實現首頁API

瀏覽:73日期:2024-09-23 11:47:15

django-rest-framework 類視圖拓展自 django 的類視圖,只是針對數據的序列化和反序列化等邏輯做了封裝。

django-rest-framework 中最基本的類視圖是 views.APIView,這個類可以看成是上一篇教程中用到的 api_view 裝飾器的類版本。這個類比較基礎,其核心功能就是 HTTP 請求預處理、分發請求給對應的處理函數,以及 HTTP 響應后處理,還有就是 as_view 方法將類轉為函數(要注意與被請求的 URL 綁定的視圖必須是一個可調用對象,普通的的類是無法被直接調用的)。除非需要深度定制視圖函數的邏輯,一般情況下我們的視圖不會直接繼承這個類。

更為通用的類視圖是 GenericAPIView,這個類繼承自 APIView,對基類的功能做了拓展。繼承自這個類的視圖,只需對其類屬性做一些簡單的配置,就能獲得獲取單個資源、獲取資源列表、資源列表分頁等功能。當然,這個類作為其他特定功能類視圖的基類,我們一般也很少使用。

回顧一下此前講的 RESTful 架構的基本概念,客戶端使用 URL 訪問資源,通過 HTTP 請求的動詞表達對資源的操作。django-rest-framework 針對各種類型的資源操作,提供了對應的通用類視圖,這些通用類視圖主要包括:

CreateAPIView

用于創建資源的 POST 請求。

ListAPIView 和 RetrieveAPIView

用于訪問資源列表和單個資源的 GET 請求。

DestroyAPIView

用于刪除資源的 DELETE 請求。

UpdateAPIView

用于更新資源的 PUT(全量更新)和 PATCH(部分更新)請求。

以及以上視圖的各種組合通用類視圖:ListCreateAPIView、RetrieveUpdateAPIView、RetrieveDestroyAPIView、RetrieveUpdateDestroyAPIView。

博客首頁 API 返回首頁文章列表數據,顯然應該選用的是 ListAPIView。其代碼如下:

from rest_framework.generics import ListAPIViewfrom rest_framework.pagination import PageNumberPaginationfrom rest_framework.permissions import AllowAnyclass IndexPostListAPIView(ListAPIView): serializer_class = PostListSerializer queryset = Post.objects.all() pagination_class = PageNumberPagination permission_classes = [AllowAny]

That all!首頁 API 就寫好了。我們基本沒有寫任何邏輯代碼,只是指定了類視圖的幾個屬性值。因為邏輯基本都是通用的,通用類視圖在背后幫我們做了全部工作,我們只要告訴它:用哪個序列化器去做,序列化哪個資源等就可以了。以這里的類視圖為例,我們指定了:

使用 PostListSerializer 序列化器(通過 serializer_class 指定);

序列化博客文章(Post)列表(通過 queryset 指定);

對資源列表分頁(通過 pagination_class 指定,PageNumberPagination 會自動對資源進行分頁,后面的教程會詳細介紹分頁功能);

允許任何人訪問該資源(通過 permission_classes 指定,AllowAny 權限類不對任何訪問做攔截,即允許任何人調用這個 API 以訪問其資源)。

最后一步就是在 urls.py 中綁定接口,把原來綁定的函數視圖改為現在的類視圖:

path(’api/index/’, views.IndexPostListAPIView.as_view())

啟動開發服務器,打開瀏覽器訪問 http://127.0.0.1:8000/api/index/,可以看到和上一篇教程中使用函數視圖返回的結果是一樣的:

{ 'count': 201, 'next': 'http://127.0.0.1:10000/api/index/?page=2', 'previous': null, 'results': [ { 'id': 1, 'title': 'Markdown 與代碼高亮測試', 'created_time': '2020-04-23T14:22:36.129383+08:00', 'excerpt': '歡迎使用馬克飛象n@(示例筆記本)[馬克飛象|幫助|Markdown]n馬克飛象是一款專為印象筆記(Ever', 'category': {'id': 6,'name': 'Markdown測試' }, 'author': {'id': 1,'username': 'admin' }, 'views': 0 } ]}

而且可以看到,返回的結果進行了分頁,next 字段指示了下一頁的鏈接,這樣分頁訪問資源就變的非常方便了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区免费观看 | 国产综合久久久久影院 | 在线播放性xxx欧美 在线播放亚洲视频 | 中文偷拍视频在线观看 | 精品videosex性欧美 | 亚州国产视频 | 亚洲线精品一区二区三区 | 欧美一级特黄一片免费 | 国产99视频精品免费观看7 | 日韩一区二区三区在线视频 | 免费特黄一级欧美大片在线看 | 成人一级毛片 | 在线91精品亚洲网站精品成人 | 欧美性猛交xxxxxxxx软件 | 91久久国产露脸精品 | 最近手机高清中文字幕大全7 | 手机在线观看毛片 | 久久亚洲国产最新网站 | 欧美一级在线观看 | 久色精品 | 日韩欧美一区二区三区免费看 | 国产激情久久久久久影院 | 99国产精品久久久久久久成人热 | 精品亚洲综合久久中文字幕 | 免费黄色网址在线播放 | 国产成人综合亚洲亚洲欧美 | 亚洲伦乱 | 99免费精品 | 亚洲精品影院久久久久久 | 视频二区 中文字幕 欧美 | 日韩精品一区二区三区免费视频 | 2019在线亚洲成年视频网站 | 免费播放aa在线视频成人 | 欧美午夜精品久久久久久黑人 | 一级片日韩 | 成人男女18免费o | 日本高清不卡在线观看 | 国产精品一国产精品 | 2019偷偷狠狠的日日 | 亚洲男女在线 | 欧美精品一二区 |