欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django的restframework接口框架自定義返回?cái)?shù)據(jù)格式的示例詳解

 更新時(shí)間:2022年07月14日 09:19:31   作者:xiejava1018  
這篇文章主要介紹了Django的restframework接口框架自定義返回?cái)?shù)據(jù)格式,本文介紹了通過Django的restframework接口框架自定義Response返回對(duì)象來自定義返回?cái)?shù)據(jù)格式,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

在前后端分離是大趨勢(shì)的背景下,前端獲取數(shù)據(jù)都是通過調(diào)用后臺(tái)的接口來獲取數(shù)據(jù)微服務(wù)的應(yīng)用越來越多。Django是Python進(jìn)行web應(yīng)用開發(fā)常用的web框架,用Django框架進(jìn)行web應(yīng)用框架減少了很多工作,通常用很少量的代碼就可以實(shí)現(xiàn)數(shù)據(jù)的增、刪、改、查的業(yè)務(wù)應(yīng)用,同樣用Django的restframework的框架對(duì)外發(fā)布接口也是非常的簡單方便,幾行代碼就可以將數(shù)據(jù)對(duì)象通過接口的方式提供服務(wù)。因?yàn)樵趯?shí)際開發(fā)過程中接口的返回?cái)?shù)據(jù)有一定的格式,本文介紹通過自定義Response返回對(duì)象來自定義接口返回?cái)?shù)據(jù)格式。

以下示例將數(shù)據(jù)對(duì)象Friend通過restframework框架進(jìn)行接口發(fā)布。
只要定義Friend數(shù)據(jù)對(duì)象

class Friend(BaseModel):
    id=models.AutoField(primary_key=True)
    siteName=models.CharField(max_length=20, verbose_name='友鏈站點(diǎn)名稱')
    path=models.CharField(max_length=100, verbose_name='地址路徑')
    desc=models.CharField(max_length=200, verbose_name='描述')

    def __str__(self):
        return self.siteName

    class Meta:
        verbose_name='友鏈'
        verbose_name_plural='友鏈'

定義一個(gè)序列化類將返回的字段序列化

class FriendModelSerializer(serializers.ModelSerializer):
    class Meta:
        model = Friend
        fields = "__all__"

定義一個(gè)接口視圖類獲取數(shù)據(jù)

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

定義接口路由就可以通過httprestfull的接口進(jìn)行訪問了

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

接口訪問效果如下:
http://localhost:8000/api/friend/

httprestfull的接口

但是在項(xiàng)目中經(jīng)常會(huì)碰到接口格式變化的情況,restframework框架默認(rèn)的返回?cái)?shù)據(jù)格式不滿足應(yīng)用的需求。比如一般的接口都會(huì)有接口返回的code、msg、data,code用來標(biāo)識(shí)接口返回代碼比如200是正常,msg用來記錄異常或其信息,data用來返回具體的數(shù)據(jù)。
通過restframework接口自定義返回?cái)?shù)據(jù)格式也是很簡單方便的。
先自定義Response返回對(duì)象,在返回對(duì)象中自定義數(shù)據(jù)返回的格式,示例代碼如下:

from rest_framework.response import Response
from rest_framework.serializers import Serializer

class CustomResponse(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)

        if isinstance(data, Serializer):
            msg = (
                'You passed a Serializer instance as data, but '
                'probably meant to pass serialized `.data` or '
                '`.error`. representation.'
            )
            raise AssertionError(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

        if headers:
            for name, value in headers.items():
                self[name] = value

在接口接口視圖類獲取數(shù)據(jù)返回時(shí),使用該自定義的Response返回對(duì)象。

class FriendView(viewsets.ModelViewSet):
    queryset = Friend.objects.all()
    serializer_class = FriendModelSerializer
    #自定義list方法,自定義Response返回
  def list(self, request, *args, **kwargs):
        queryset = self.filter_queryset(self.get_queryset())
        serializer = self.get_serializer(queryset, many=True)
        return CustomResponse(data=serializer.data, code=200, msg="OK", status=status.HTTP_200_OK)

接口訪問效果如下:
可以看到返回?cái)?shù)據(jù)格式中增加了code,msg 數(shù)據(jù)放到了data節(jié)點(diǎn)

自定義數(shù)據(jù)返回格式

列表數(shù)據(jù)通常接口要提供翻頁功能,在接口中要有總頁數(shù)、當(dāng)前頁、是否有下一頁的信息。
可以自定義一個(gè)分頁器,在分頁器中自定義需要返回的分頁參數(shù)
參考示例代碼如下:

from rest_framework import status
from rest_framework.pagination import PageNumberPagination
from common.customresponse import CustomResponse

class MyPage(PageNumberPagination):
    page_size = 8 #每頁顯示數(shù)量
    max_page_size = 50 #每頁最大顯示數(shù)量。
    page_size_query_param = 'size' #每頁數(shù)量的參數(shù)名稱
    page_query_param = 'page'  #頁碼的參數(shù)名稱

    def get_paginated_response(self, data):
        #自定義分頁器的返回參數(shù)
        return CustomResponse(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)

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

class FriendView(viewsets.ModelViewSet):
    queryset = Friend.objects.all()
    serializer_class = FriendModelSerializer
    pagination_class = MyPage
    #自定義list方法,自定義Response返回
    def list(self, request, *args, **kwargs):
        queryset = self.filter_queryset(self.get_queryset())
        page = self.paginate_queryset(queryset)
        #如果有分頁器,則進(jìn)行分頁后返回
        if page is not None:
            serializer = self.get_serializer(page, many=True)
            return self.get_paginated_response(serializer.data)

        serializer = self.get_serializer(queryset, many=True)
        return CustomResponse(data=serializer.data, code=200, msg="OK", status=status.HTTP_200_OK)

接口訪問效果如下:
可以看到接口中自定義增加了分頁信息。

接口中自定義增加了分頁信息

但是有時(shí)候可能希望分頁的信息數(shù)據(jù)要放在data節(jié)點(diǎn)里面,這樣也是可以做到的。

from rest_framework import status
from rest_framework.pagination import PageNumberPagination
from common.customresponse import CustomResponse

class MyPage(PageNumberPagination):
    page_size = 8 #每頁顯示數(shù)量
    max_page_size = 50 #每頁最大顯示數(shù)量。
    page_size_query_param = 'size' #每頁數(shù)量的參數(shù)名稱
    page_query_param = 'page'  #頁碼的參數(shù)名稱

    #自定義分頁器的返回參數(shù)
    def get_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
        return CustomResponse(data=ret_data,code=200,msg="OK",status=status.HTTP_200_OK)

接口訪問效果如下:
可以看到接口中自定義增加了分頁信息,分頁的信息數(shù)據(jù)放在data節(jié)點(diǎn)里面了

自定義增加了分頁信息,分頁的信息數(shù)據(jù)放在data節(jié)點(diǎn)里面

至此,本文介紹了通過Django的restframework接口框架自定義Response返回對(duì)象來自定義返回?cái)?shù)據(jù)格式。Django的restframework接口框架使用簡單方便,拿來即用,能夠很大程度上減少代碼開發(fā)量。

到此這篇關(guān)于Django的restframework接口框架自定義返回?cái)?shù)據(jù)格式的文章就介紹到這了,更多相關(guān)Django restframework自定義返回?cái)?shù)據(jù)格式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python文件和目錄操作詳解

    Python文件和目錄操作詳解

    這篇文章主要介紹了Python文件和目錄操作詳解,本文講解了文件的打開和創(chuàng)建、文件的讀取、文件的寫入、內(nèi)容查找替換等內(nèi)容,需要的朋友可以參考下
    2015-02-02
  • python調(diào)用新浪微博API項(xiàng)目實(shí)踐

    python調(diào)用新浪微博API項(xiàng)目實(shí)踐

    因?yàn)樽罱佑|到調(diào)用新浪微博開放接口的項(xiàng)目,所以就想試試用python調(diào)用微博API,需要的朋友可以參考下
    2014-07-07
  • python命令行執(zhí)行腳本找不到模塊ModuleNotFoundError問題

    python命令行執(zhí)行腳本找不到模塊ModuleNotFoundError問題

    這篇文章主要介紹了python命令行執(zhí)行腳本找不到模塊ModuleNotFoundError問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Python的Django框架中自定義模版標(biāo)簽的示例

    Python的Django框架中自定義模版標(biāo)簽的示例

    這篇文章主要介紹了Python的Django框架中自定義模版標(biāo)簽的示例,標(biāo)簽的用處比過濾器更多,需要的朋友可以參考下
    2015-07-07
  • Python循環(huán)結(jié)構(gòu)的應(yīng)用場(chǎng)景詳解

    Python循環(huán)結(jié)構(gòu)的應(yīng)用場(chǎng)景詳解

    這篇文章主要介紹了Python循環(huán)結(jié)構(gòu)的應(yīng)用場(chǎng)景詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Python 批量下載陰陽師網(wǎng)站壁紙

    Python 批量下載陰陽師網(wǎng)站壁紙

    學(xué)習(xí)要始于興趣,自己學(xué)習(xí)python的一大初衷是希望能用于寫一些簡單的游戲腳本,能服務(wù)于生活。所以決定試著直接從爬取我最愛玩的陰陽師網(wǎng)站的一些壁紙開始
    2021-05-05
  • python求列表交集的方法匯總

    python求列表交集的方法匯總

    這篇文章主要介紹了python求列表交集的方法,實(shí)例匯總了三個(gè)常用的方法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-11-11
  • Python中json.load()和json.loads()有哪些區(qū)別

    Python中json.load()和json.loads()有哪些區(qū)別

    json.loads()用于解析一個(gè)有效的JSON字符串并將其轉(zhuǎn)換為Python字典,json.load——()用于從一個(gè)文件讀取JSON類型的數(shù)據(jù),然后轉(zhuǎn)轉(zhuǎn)換成Python字典,本文講解下python中兩者的使用
    2021-06-06
  • django框架基于模板 生成 excel(xls) 文件操作示例

    django框架基于模板 生成 excel(xls) 文件操作示例

    這篇文章主要介紹了django框架基于模板 生成 excel(xls) 文件操作,結(jié)合具體實(shí)例形式分析了Django框架基于模板生成excel的實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • Python Pandas模塊實(shí)現(xiàn)數(shù)據(jù)的統(tǒng)計(jì)分析的方法

    Python Pandas模塊實(shí)現(xiàn)數(shù)據(jù)的統(tǒng)計(jì)分析的方法

    在上一篇講了幾個(gè)常用的“Pandas”函數(shù)之后,今天小編就為大家介紹一下在數(shù)據(jù)統(tǒng)計(jì)分析當(dāng)中經(jīng)常用到的“Pandas”函數(shù)方法,希望能對(duì)大家有所收獲,需要的朋友可以參考下
    2021-06-06

最新評(píng)論