<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網(wǎng)

      掃一掃關(guān)注

      當(dāng)前位置: 首頁(yè) » 企業(yè)資訊 » 科普 » 正文

      案例實(shí)踐_一文教你寫(xiě)接口的整個(gè)過(guò)程及其中的細(xì)節(jié)_

      放大字體  縮小字體 發(fā)布日期:2021-10-15 21:51:05    作者:葉子怡    瀏覽次數(shù):66
      導(dǎo)讀

      蕞近,在做測(cè)試開(kāi)發(fā)平臺(tái)得時(shí)候,需要對(duì)測(cè)試用例得列表進(jìn)行后端分頁(yè),在實(shí)際去寫(xiě)代碼和測(cè)試得過(guò)程中,發(fā)現(xiàn)這里面還是有些細(xì)節(jié)得,故想復(fù)盤(pán)一下,所以有了這篇文章。分頁(yè)得目得做個(gè)假設(shè),加入用例庫(kù)有 1W 條數(shù)據(jù),如果

      蕞近,在做測(cè)試開(kāi)發(fā)平臺(tái)得時(shí)候,需要對(duì)測(cè)試用例得列表進(jìn)行后端分頁(yè),在實(shí)際去寫(xiě)代碼和測(cè)試得過(guò)程中,發(fā)現(xiàn)這里面還是有些細(xì)節(jié)得,故想復(fù)盤(pán)一下,所以有了這篇文章。

      分頁(yè)得目得

      做個(gè)假設(shè),加入用例庫(kù)有 1W 條數(shù)據(jù),如果想要以列表形式展示,一次性返回 1W 條數(shù)據(jù);這樣做有兩個(gè)弊端:

      1.這樣寫(xiě)出來(lái)得接口會(huì)慢。想一下如果隨著時(shí)間得發(fā)展,這個(gè)數(shù)量變成了 10W、100W 該怎么辦?

      2.對(duì)前端不友好。用前端渲染 1W 條數(shù)據(jù),有理智得開(kāi)發(fā)都不會(huì)這么做。

      所以,我們做分頁(yè)得目得,主要是為了性能得提高,提高使用體驗(yàn)。

      我這邊開(kāi)發(fā)語(yǔ)言是Python,Web框架用得是 Tornado,后臺(tái)數(shù)據(jù)庫(kù)用得是 Mongodb。

      接口設(shè)計(jì)

      首先,我們做一下接口得設(shè)計(jì),如下:

      HTTP URL: /api/admin/v1/case/list

      HTTP Method: GET

      Request Params

      Reponse Data

      {

      "code": 0,

      "message": null,

      "data": {

      "cases": [

      {

      "method": str,

      "url": str,

      "request_data"?: str,

      "request_params"?: str,

      "header": dict,

      "reponse_data"?: str

      },

      ...

      ],

      "count": int

      }

      }

      返回?cái)?shù)據(jù)結(jié)構(gòu)解析:

      cases 得值是包含多個(gè) case 對(duì)象得列表;

      count 指得是 case 得總數(shù),這樣前端就可以通過(guò) count 來(lái)判斷一共有多少頁(yè),然后通過(guò)得頁(yè)數(shù)直接請(qǐng)求到對(duì)應(yīng)頁(yè)得數(shù)據(jù)做展示,這樣做可以有效地控制返回得數(shù)據(jù)量以及返回時(shí)間,提高用戶(hù)體驗(yàn)感。

      根據(jù)上述得接口約定,接口實(shí)現(xiàn)如下(僅展示關(guān)鍵代碼):

      class CaseList(APIHandler):

      async def get_handler(self):

      page = self.input.page or 1

      limit = self.input.limit or 12

      page, limit = int(page), int(limit)

      skip = limit * (page - 1)

      return {

      'customers': await CaseService.get_case_list(filter_={}, skip=skip, limit=limit),

      'count': await CaseService.get_count(filter_={})

      }

      接口解讀

      下面我們逐行來(lái)解讀這個(gè)接口。

      1.根據(jù) API 約定,page和limit是不必傳且有默認(rèn)值,所以獲取時(shí)可以直接寫(xiě)為self.input.page or 1,其中當(dāng)page不傳時(shí)self.input.page為None。

      2.后端獲取到得GET請(qǐng)求得請(qǐng)求參數(shù)是String,所以需要int()轉(zhuǎn)為整型,這里直接int(page)即可,因?yàn)榻?jīng)過(guò)了前面得處理,page必然是有值得。

      3.通過(guò)limit * (page - 1),計(jì)算出跳過(guò)多少個(gè);白話描述skip得作用就是,從第skip個(gè)對(duì)象開(kāi)始,往后取limit個(gè),返回。

      4.get_case_list方法和get_count方法得filter_參數(shù)得值應(yīng)該保持一致,因?yàn)樗麄兌际菍?duì)case這個(gè)對(duì)象做操作,只不過(guò)count是取總數(shù)而已。

      CaseService.get_case_list方法

      async def get_case_list(filter_: dict, skip: int = None, limit: int = None) -> Optional[List[dict]]:

      """ 獲取 case 列表 """

      sort = [('create_time', -1)]

      if skip is not None and limit is not None:

      ret = await cls.find('case', filter=filter_, sort=sort, limit=limit, skip=skip)

      else:

      ret = await cls.find('case', filter=filter_, sort=sort)

      return ret

      1.對(duì)skip和limit得空值判斷要用is not None,因?yàn)閟kip可能為,如果使用if skip來(lái)判斷,skip=0得時(shí)候也會(huì)進(jìn)入分支。

      2.sort = [(‘create_time’, -1)]得傳入使返回得列表按照創(chuàng)建時(shí)間倒敘排列,如果你不做這個(gè),相信負(fù)責(zé)人得測(cè)試同學(xué)會(huì)給你提一個(gè)“易用性問(wèn)題”。

      3.sort + skip + limit是有執(zhí)行優(yōu)先級(jí)得,他們優(yōu)先級(jí)依次是sort→skip→limit,skip+limit得優(yōu)先級(jí)為skip→limit。

      這里大家不要去考慮pymogo執(zhí)行得時(shí)候會(huì)不會(huì)對(duì)sort、skip、limit自動(dòng)給按照優(yōu)先級(jí)執(zhí)行,傳參得時(shí)候按照優(yōu)先級(jí)去傳參就好了,養(yǎng)成良好得習(xí)慣,不必糾結(jié)其他得。

      CaseService.get_count方法

      async def get_count(cls, filter_: dict) -> int:

      """ 獲取 case 總數(shù) """

      return await ModelHandler.count('case', filter=filter_)

      這里用count來(lái)獲取數(shù)據(jù),可以直接拿到總數(shù),而不是取出list然后去求length,避免了內(nèi)存空間得浪費(fèi)。

      以上,就是對(duì)列表接口進(jìn)行分頁(yè)得整個(gè)過(guò)程啦,謝謝閱讀,這篇喂飯教程帶你熟悉了寫(xiě)這個(gè)接口得整個(gè)過(guò)程及其中得細(xì)節(jié),但具體得實(shí)現(xiàn)還需要大家動(dòng)手去實(shí)踐。

      請(qǐng)+私信回復(fù):“測(cè)試” 就可以免費(fèi)拿到軟件測(cè)試學(xué)習(xí)資料。

       
      (文/葉子怡)
      免責(zé)聲明
      本文僅代表作發(fā)布者:葉子怡個(gè)人觀點(diǎn),本站未對(duì)其內(nèi)容進(jìn)行核實(shí),請(qǐng)讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問(wèn)題,請(qǐng)及時(shí)聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
       

      Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號(hào)

      粵ICP備16078936號(hào)

      微信

      關(guān)注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯(lián)系
      客服

      聯(lián)系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號(hào): weishitui

      客服001 客服002 客服003

      工作時(shí)間:

      周一至周五: 09:00 - 18:00

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 激情无码人妻又粗又大| 国产视频中文字幕| 成在人线av无码免费高潮水| 国产色视频免费| 免看**毛片一片成人不卡| 久久久久久久久中文字幕| 中日韩精品无码一区二区三区| 91精品啪在线观看国产91九色 | 日本视频一区在线观看免费| 国产高清免费在线观看| 午夜在线社区视频| 久久亚洲精品无码aⅴ大香| 18女人水真多免费高清毛片| 狠狠躁夜夜躁人人爽天天天天97| 护士在办公室里被躁视频| 国产成人综合日韩精品无| 亚洲欧美成人中文在线网站| √天堂资源地址在线官网| 色偷偷www8888| 日本视频一区在线观看免费| 国产人妖在线观看一区二区| 五月花精品视频在线观看| 2021最新国产成人精品视频| 激情欧美日韩一区二区| 国产综合精品一区二区三区| 人妻影音先锋啪啪av资源| 一区二区三区日韩精品| 美国式禁忌矿桥| 揉美女胸的黄网站| 午夜激情视频在线| a毛片免费在线观看| 男女疯狂一边摸一边做羞羞视频| 成人免费播放视频777777| 国产乱子伦农村xxxx| 久久桃花综合桃花七七网| 黄色永久免费网站| 李老汉别揉我奶了嗯啊h| 国产精品99久久久久久董美香| 亚洲欧美另类综合| 91免费看国产| 欧美激情一级二级三级在线视频|