Django REST framework 視圖和路由詳解
DRF中的Request
在Django REST Framework中內(nèi)置的Request類擴(kuò)展了Django中的Request類,實(shí)現(xiàn)了很多方便的功能--如請(qǐng)求數(shù)據(jù)解析和認(rèn)證等。
比如,區(qū)別于Django中的request從request.GET中獲取URL參數(shù),從request.POST中取某些情況下的POST數(shù)據(jù)。
在APIView中封裝的request,就實(shí)現(xiàn)了請(qǐng)求數(shù)據(jù)的解析:
對(duì)于GET請(qǐng)求的參數(shù)我們通過(guò)request.query_params來(lái)獲取。
對(duì)于POST請(qǐng)求、PUT請(qǐng)求的數(shù)據(jù)我們通過(guò)request.data來(lái)獲取。
前提
序列化
from rest_framework import serializers
from app01 import models
class CommentSerializer(serializers.ModelSerializer):
class Meta:
model = models.Comment
fields = "__all__"
extra_kwargs = {
"content": {"error_messages": {"required": "評(píng)論內(nèi)容不能為空"}},
"article": {"error_messages": {"required": "文章不能為空"}}
}
class SchoolSerializer(serializers.ModelSerializer):
class Meta:
model = models.School
fields = "__all__"
第一階段:手壘代碼
視圖
from rest_framework.views import APIView
class SchoolView(APIView):
def get(self, request, *args, **kwargs):
query_set = models.School.objects.all()
ser_obj = app01_serializers.SchoolSerializer(query_set, many=True)
return Response(ser_obj.data)
class SchoolDetail(APIView):
def get(self, request, pk, *args, **kwargs):
obj = models.School.objects.filter(pk=pk).first()
ser_obj = app01_serializers.SchoolSerializer(obj)
return Response(ser_obj.data)
第二階段:簡(jiǎn)單使用rest formwork自帶混合類方法
視圖
from rest_framework.generics import GenericAPIView # 公共類
from rest_framework.mixins import ListModelMixin, RetrieveModelMixin, CreateModelMixin # 混合類 必須與公共類搭配著使用
class SchoolView(GenericAPIView, mixins.ListModelMixin): # 查看學(xué)校列表
queryset = models.School.objects.all()
serializer_class = app01_serializers.SchoolSerializer
def get(self, request, *args, **kwargs):
return self.list(request, *args, **kwargs)
class SchoolDetail(GenericAPIView, mixins.RetrieveModelMixin, mixins.CreateModelMixin): # 創(chuàng)建,與具體查出某一條記錄
queryset = models.School.objects.all()
serializer_class = app01_serializers.SchoolSerializer
def get(self, request, pk, *args, **kwargs):
return self.retrieve(request, pk, *args, **kwargs)
def post(self, request, *args, **kwargs):
return self.create(request, *args, **kwargs)
路由
url(r'school/$', views.SchoolView.as_view()), url(r'school/(?P<pk>\d+)/$', views.SchoolDetail.as_view()),
第三階段:使用rest formwork自帶的通用類方法
視圖
from rest_framework.generics import GenericAPIView, ListCreateAPIView, RetrieveUpdateAPIVie class SchoolView(ListCreateAPIView): # 創(chuàng)建 queryset = models.School.objects.all() serializer_class = app01_serializers.SchoolSerializer class SchoolDetail(RetrieveUpdateDestroyAPIView): # 更新 queryset = models.School.objects.all() serializer_class = app01_serializers.SchoolSerializer
路由同上
第四階段:使用rest formwork自帶的封裝所有放的類,代碼量最少,功能最全
視圖
from rest_framework.viewsets import ModelViewSet # 里面封裝了操作的所有方法,增刪改查查 class SchoolView(ModelViewSet): queryset = models.School.objects.all() serializer_class = app01_serializers.SchoolSerializer
路由
url(r'school/$', views.SchoolView.as_view(actions={
"get": "list",
"post": "create",
})),
url(r'school/(?P<pk>\d+)/$', views.SchoolView.as_view(actions={
'get': 'retrieve',
'put': 'update',
'patch': 'partial_update',
'delete': 'destroy'
})),
高級(jí)路由
視圖
同上
路由
from rest_framework.routers import DefaultRouter router = DefaultRouter() router.register(r'school', views.SchoolView) urlpatterns += router.urls
精華:流程圖

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Django 項(xiàng)目通過(guò)加載不同env文件來(lái)區(qū)分不同環(huán)境
這篇文章主要介紹了Django 項(xiàng)目如何通過(guò)加載不同env文件來(lái)區(qū)分不同環(huán)境,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
Python抓包并解析json爬蟲(chóng)的完整實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于Python抓包并解析json爬蟲(chóng)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Django中日期時(shí)間型字段進(jìn)行年月日時(shí)分秒分組統(tǒng)計(jì)
這篇文章主要介紹了Django中日期時(shí)間型字段進(jìn)行年月日時(shí)分秒分組統(tǒng)計(jì),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
分析運(yùn)行中的 Python 進(jìn)程詳細(xì)解析
這篇文章主要介紹了分析運(yùn)行中的 Python 進(jìn)程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
Pycharm配置opencv與numpy的實(shí)現(xiàn)
本文總結(jié)了兩種方法來(lái)導(dǎo)入opencv與numpy包,第一種是直接在Pycharm中導(dǎo)入兩個(gè)包,第二種是在官網(wǎng)下載相關(guān)文件進(jìn)行配置,感興趣的小伙伴們可以參考一下2021-07-07
Python實(shí)現(xiàn)監(jiān)控程序執(zhí)行時(shí)間并將其寫(xiě)入日志的方法
這篇文章主要介紹了Python實(shí)現(xiàn)監(jiān)控程序執(zhí)行時(shí)間并將其寫(xiě)入日志的方法,實(shí)例分析了Python日志操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06
keras.layers.Layer中無(wú)法定義name的問(wèn)題及解決
這篇文章主要介紹了keras.layers.Layer中無(wú)法定義name的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Python多線程編程(八):使用Event實(shí)現(xiàn)線程間通信
這篇文章主要介紹了Python多線程編程(八):使用Event實(shí)現(xiàn)線程間通信,,需要的朋友可以參考下2015-04-04
cv2.imread?和?cv2.imdecode?用法及區(qū)別
對(duì)于路徑中含有中文的圖像,直接用cv2.imread讀取會(huì)報(bào)錯(cuò),上次看到有大佬使用cv2.imdecode就可以正常讀取,有點(diǎn)好奇,所以今天來(lái)記錄下二者用法和區(qū)別,感興趣的朋友跟隨小編一起看看吧2023-02-02

