国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Django的restframework接口處的框架進行自定義返回數據格式代碼詳解

89542767 / 916人閱讀


  小編寫這篇文章的主要目的,就是給大家進行介紹在python中,使用Djangorestframework接口處的框架進行自定義返回數據,并給大家貼出了具體代碼,大家可以進行仔細的閱讀。

 

  就目前來看,前后端分離是一個比較大的趨勢,前端獲取數據的方式,主要是通過調用接口的形式,來獲取到后端的應用服務。DjangoPython進行web應用開發常用的web框架,用Django框架進行web應用框架減少了很多工作,使用較少的代碼,就能完成很大的一個工作量。

 

  同樣用Djangorestframework的相關框架,向外部,幾行代碼就可以將數據對象通過接口的方式提供服務。因為在實際開發過程中接口的返回數據有一定的格式,本文介紹通過自定義Response返回對象來自定義接口返回數據格式。

 

  以下示例將數據對象Friend通過restframework框架進行接口發布。

 

  只要定義Friend數據對象

 

  classFriend(BaseModel):
  id=models.AutoField(primary_key=True)
  siteName=models.CharField(max_length=20,verbose_name='友鏈站點名稱')
  path=models.CharField(max_length=100,verbose_name='地址路徑')
  desc=models.CharField(max_length=200,verbose_name='描述')
  def__str__(self):
  returnself.siteName
  classMeta:
  verbose_name='友鏈'
  verbose_name_plural='友鏈'

 

  定義一個序列化類將返回的字段序列化

 

 

 classFriendModelSerializer(serializers.ModelSerializer):
  classMeta:
  model=Friend
  fields="__all__"

 

  定義一個接口視圖類獲取數據

 

 

 classFriendView(viewsets.ModelViewSet):
  queryset=Friend.objects.all()
  serializer_class=FriendModelSerializer

 

  定義接口路由就可以通過httprestfull的接口進行訪問了

 

 

 friend_list=views.FriendView.as_view({'get':'list',})
  urlpatterns=[
  path('friend/',friend_list),
  ]

  接口訪問效果如下:

 

  http://localhost:8000/api/friend/

0.png 

  但是在項目中經常會碰到接口格式變化的情況,restframework框架默認的返回數據格式不滿足應用的需求。比如一般的接口都會有接口返回的code、msg、data,code用來標識接口返回代碼比如200是正常,msg用來記錄異常或其信息,data用來返回具體的數據。

 

  通過restframework接口自定義返回數據格式也是很簡單方便的。

 

  先自定義Response返回對象,在返回對象中自定義數據返回的格式,示例代碼如下:

 

  fromrest_framework.responseimportResponse
  fromrest_framework.serializersimportSerializer
  classCustomResponse(Response):
  def__init__(self,data=None,code=None,msg=None,
  status=None,
  template_name=None,headers=None,
  exception=False,content_type=None,**kwargs):
  super().__init__(None,status=status)
  ifisinstance(data,Serializer):
  msg=(
  'YoupassedaSerializerinstanceasdata,but'
  'probablymeanttopassserialized`.data`or'
  '`.error`.representation.'
  )
  raiseAssertionError(msg)
  #自定義返回格式
  self.data={'code':code,'msg':msg,'data':data}
  self.data.update(kwargs)
  self.template_name=template_name
  self.exception=exception
  self.content_type=content_type
  ifheaders:
  forname,valueinheaders.items():
  self[name]=value
  在接口接口視圖類獲取數據返回時,使用該自定義的Response返回對象。
  classFriendView(viewsets.ModelViewSet):
  queryset=Friend.objects.all()
  serializer_class=FriendModelSerializer
  #自定義list方法,自定義Response返回
  deflist(self,request,*args,**kwargs):
  queryset=self.filter_queryset(self.get_queryset())
  serializer=self.get_serializer(queryset,many=True)
  returnCustomResponse(data=serializer.data,code=200,msg="OK",status=status.HTTP_200_OK)

  接口訪問效果如下:

 

  可以看到返回數據格式中增加了code,msg數據放到了data節點

1.png

  列表數據通常接口要提供翻頁功能,在接口中要有總頁數、當前頁、是否有下一頁的信息。

 

  可以自定義一個分頁器,在分頁器中自定義需要返回的分頁參數

 

  參考示例代碼如下:

 

  fromrest_frameworkimportstatus
  fromrest_framework.paginationimportPageNumberPagination
  fromcommon.customresponseimportCustomResponse
  classMyPage(PageNumberPagination):
  page_size=8#每頁顯示數量
  max_page_size=50#每頁最大顯示數量。
  page_size_query_param='size'#每頁數量的參數名稱
  page_query_param='page'#頁碼的參數名稱
  defget_paginated_response(self,data):
  #自定義分頁器的返回參數
  returnCustomResponse(data=data,code=200,msg="OK",status=status.HTTP_200_OK,count=self.page.paginator.count,next=self.get_next_link(),previous=self.get_previous_link(),size=self.page_size,page=self.page.number)

  在接口接口視圖類獲取數據返回時,如果有分頁器則使用該分頁器自定義的Response返回對象。

 

  classFriendView(viewsets.ModelViewSet):

 

  queryset=Friend.objects.all()

 

  serializer_class=FriendModelSerializer

 

  pagination_class=MyPage

 

  #自定義list方法,自定義Response返回

 

  deflist(self,request,*args,**kwargs):

 

  queryset=self.filter_queryset(self.get_queryset())

 

  page=self.paginate_queryset(queryset)

 

  #如果有分頁器,則進行分頁后返回

 

  ifpageisnotNone:

 

  serializer=self.get_serializer(page,many=True)

 

  returnself.get_paginated_response(serializer.data)

 

  serializer=self.get_serializer(queryset,many=True)

 

  returnCustomResponse(data=serializer.data,code=200,msg="OK",status=status.HTTP_200_OK)

 

  接口訪問效果如下:

 

  可以看到接口中自定義增加了分頁信息。

3.png

  但是有時候可能希望分頁的信息數據要放在data節點里面,這樣也是可以做到的。

 

 

 fromrest_frameworkimportstatus
  fromrest_framework.paginationimportPageNumberPagination
  fromcommon.customresponseimportCustomResponse
  classMyPage(PageNumberPagination):
  page_size=8#每頁顯示數量
  max_page_size=50#每頁最大顯示數量。
  page_size_query_param='size'#每頁數量的參數名稱
  page_query_param='page'#頁碼的參數名稱
  #自定義分頁器的返回參數
  defget_paginated_response(self,data):
  ret_data=dict()
  ret_data['items']=data
  #加入自定義分頁信息
  ret_data['total']=self.page.paginator.count
  ret_data['hasNextPage']=self.get_next_link()
  ret_data['size']=self.page_size
  ret_data['page']=self.page.number
  returnCustomResponse(data=ret_data,code=200,msg="OK",status=status.HTTP_200_OK)

 

  接口訪問效果如下:

4.png

  可以看到接口中自定義增加了分頁信息,分頁的信息數據放在data節點里面了

 

  至此,本文介紹了通過Djangorestframework接口框架自定義Response返回對象來自定義返回數據格式。Djangorestframework接口框架使用簡單方便,拿來即用,能夠很大程度上減少代碼開發量。

 

 


文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/127709.html

相關文章

  • Django + Django REST framework步驟總結

    摘要:主要記錄一下的步驟總結,第一次鼓搗后臺和,代碼寫得可能有點亂此項目的部署記錄點擊這里一創建配置項目項目初始配置創建項目安裝數據庫驅動更改數據庫配置這里為了方便就直接用了數據庫引擎數據庫名賬戶名密碼主機端口接著在添加如下代碼設置中改為自己的 主要記錄一下Django + Django REST framework的步驟總結,第一次鼓搗后臺和python,代碼寫得可能有點亂此demo項目的...

    snowLu 評論0 收藏0
  • Django + Django REST framework步驟總結

    摘要:主要記錄一下的步驟總結,第一次鼓搗后臺和,代碼寫得可能有點亂此項目的部署記錄點擊這里一創建配置項目項目初始配置創建項目安裝數據庫驅動更改數據庫配置這里為了方便就直接用了數據庫引擎數據庫名賬戶名密碼主機端口接著在添加如下代碼設置中改為自己的 主要記錄一下Django + Django REST framework的步驟總結,第一次鼓搗后臺和python,代碼寫得可能有點亂此demo項目的...

    李義 評論0 收藏0
  • Django + Django REST framework步驟總結

    摘要:主要記錄一下的步驟總結,第一次鼓搗后臺和,代碼寫得可能有點亂此項目的部署記錄點擊這里一創建配置項目項目初始配置創建項目安裝數據庫驅動更改數據庫配置這里為了方便就直接用了數據庫引擎數據庫名賬戶名密碼主機端口接著在添加如下代碼設置中改為自己的 主要記錄一下Django + Django REST framework的步驟總結,第一次鼓搗后臺和python,代碼寫得可能有點亂此demo項目的...

    chaosx110 評論0 收藏0
  • django官方文檔1.11編翻:首頁

    摘要:源網頁說明文檔所有關于你應該且必須知道的。性能和優化概述的兼容性旨在兼容多種不同版本的支持的兼容性地理框架打算成為世界級的地理框架。其目標是盡可能簡單地構建應用程序并利用空間使能數據的功能。 源網頁:https://docs.djangoproject.co... django說明文檔 所有關于django你應該且必須知道的。 第一步 你是否django編程新手,那就從此開始!從零開始...

    Michael_Lin 評論0 收藏0
  • Django-03.靜態文件與模板詳解

    摘要:通過使用來給子模板開放接口。必須是模板中的第一個出現的標簽。如果出現重復代碼,就應該考慮使用模板。盡可能多的定義,方便子模板實現更細的需求。 1、原始渲染 在django_lesson文件夾下新建一個django工程lesson2(新建工程的詳情請見Django-01、初識Django和搭建Django helloworld)views.py # -*- coding: utf-8 -...

    ls0609 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<