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

用Python編寫web API的教程

 更新時(shí)間:2015年04月30日 10:10:27   作者:廖雪峰  
這篇文章主要介紹了用Python編寫web API的教程,示例代碼基于Python2.x版本,需要的朋友可以參考下

自從Roy Fielding博士在2000年他的博士論文中提出REST(Representational State Transfer)風(fēng)格的軟件架構(gòu)模式后,REST就基本上迅速取代了復(fù)雜而笨重的SOAP,成為Web API的標(biāo)準(zhǔn)了。

什么是Web API呢?

如果我們想要獲取一篇Blog,輸入http://localhost:9000/blog/123,就可以看到id為123的Blog頁面,但這個(gè)結(jié)果是HTML頁面,它同時(shí)混合包含了Blog的數(shù)據(jù)和Blog的展示兩個(gè)部分。對(duì)于用戶來說,閱讀起來沒有問題,但是,如果機(jī)器讀取,就很難從HTML中解析出Blog的數(shù)據(jù)。

如果一個(gè)URL返回的不是HTML,而是機(jī)器能直接解析的數(shù)據(jù),這個(gè)URL就可以看成是一個(gè)Web API。比如,讀取http://localhost:9000/api/blogs/123,如果能直接返回Blog的數(shù)據(jù),那么機(jī)器就可以直接讀取。

REST就是一種設(shè)計(jì)API的模式。最常用的數(shù)據(jù)格式是JSON。由于JSON能直接被JavaScript讀取,所以,以JSON格式編寫的REST風(fēng)格的API具有簡單、易讀、易用的特點(diǎn)。

編寫API有什么好處呢?由于API就是把Web App的功能全部封裝了,所以,通過API操作數(shù)據(jù),可以極大地把前端和后端的代碼隔離,使得后端代碼易于測(cè)試,前端代碼編寫更簡單。

一個(gè)API也是一個(gè)URL的處理函數(shù),我們希望能直接通過一個(gè)@api來把函數(shù)變成JSON格式的REST API,這樣,獲取注冊(cè)用戶可以用一個(gè)API實(shí)現(xiàn)如下:

@api
@get('/api/users')
def api_get_users():
  users = User.find_by('order by created_at desc')
  # 把用戶的口令隱藏掉:
  for u in users:
    u.password = '******'
  return dict(users=users)

所以,@api這個(gè)decorator只要編寫好了,就可以把任意的URL處理函數(shù)變成API調(diào)用。

新建一個(gè)apis.py,編寫@api負(fù)責(zé)把函數(shù)的返回結(jié)果序列化為JSON:

def api(func):
  @functools.wraps(func)
  def _wrapper(*args, **kw):
    try:
      r = json.dumps(func(*args, **kw))
    except APIError, e:
      r = json.dumps(dict(error=e.error, data=e.data, message=e.message))
    except Exception, e:
      r = json.dumps(dict(error='internalerror', data=e.__class__.__name__, message=e.message))
    ctx.response.content_type = 'application/json'
    return r
  return _wrapper

@api需要對(duì)Error進(jìn)行處理。我們定義一個(gè)APIError,這種Error是指API調(diào)用時(shí)發(fā)生了邏輯錯(cuò)誤(比如用戶不存在),其他的Error視為Bug,返回的錯(cuò)誤代碼為internalerror。

客戶端調(diào)用API時(shí),必須通過錯(cuò)誤代碼來區(qū)分API調(diào)用是否成功。錯(cuò)誤代碼是用來告訴調(diào)用者出錯(cuò)的原因。很多API用一個(gè)整數(shù)表示錯(cuò)誤碼,這種方式很難維護(hù)錯(cuò)誤碼,客戶端拿到錯(cuò)誤碼還需要查表得知錯(cuò)誤信息。更好的方式是用字符串表示錯(cuò)誤代碼,不需要看文檔也能猜到錯(cuò)誤原因。

可以在瀏覽器直接測(cè)試API,例如,輸入http://localhost:9000/api/users,就可以看到返回的JSON:

相關(guān)文章

  • Django項(xiàng)目中包含多個(gè)應(yīng)用時(shí)對(duì)url的配置方法

    Django項(xiàng)目中包含多個(gè)應(yīng)用時(shí)對(duì)url的配置方法

    今天小編就為大家分享一篇Django項(xiàng)目中包含多個(gè)應(yīng)用時(shí)對(duì)url的配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 在Python中處理XML的教程

    在Python中處理XML的教程

    這篇文章主要介紹了在Python中處理XML的教程,是Python網(wǎng)絡(luò)編程中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-04-04
  • Python-VTK隱式函數(shù)屬性選擇和剪切數(shù)據(jù)

    Python-VTK隱式函數(shù)屬性選擇和剪切數(shù)據(jù)

    這篇文章主要介紹了Python-VTK隱式函數(shù)屬性選擇和剪切數(shù)據(jù),VTK,是一個(gè)開放資源的免費(fèi)軟件系統(tǒng),主要用于三維計(jì)算機(jī)圖形學(xué)、圖像處理和可視化,下面文章主題相關(guān)詳細(xì)內(nèi)容需要的小伙伴可以參考一下
    2022-04-04
  • 關(guān)于matlab圖像濾波詳解(二維傅里葉濾波)

    關(guān)于matlab圖像濾波詳解(二維傅里葉濾波)

    這篇文章主要介紹了關(guān)于matlab圖像濾波詳解(二維傅里葉濾波),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Flask?使用類組織配置詳情

    Flask?使用類組織配置詳情

    這篇文章主要介紹了Flask使用類組織配置,在實(shí)際的項(xiàng)目中,我們一般都會(huì)建立三個(gè)環(huán)境:開發(fā)、測(cè)試和生產(chǎn)環(huán)境,這三種環(huán)境會(huì)使用不同的配置組合,為了能方便地切換配置,我們可以為不同的環(huán)境創(chuàng)建不同的配置文件,下面來看詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2021-11-11
  • django2筆記之路由path語法的實(shí)現(xiàn)

    django2筆記之路由path語法的實(shí)現(xiàn)

    這篇文章主要介紹了django2筆記之路由path語法的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Python在不同目錄下導(dǎo)入模塊的實(shí)現(xiàn)方法

    Python在不同目錄下導(dǎo)入模塊的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄狿ython在不同目錄下導(dǎo)入模塊的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • python基于搜索引擎實(shí)現(xiàn)文章查重功能

    python基于搜索引擎實(shí)現(xiàn)文章查重功能

    這篇文章主要介紹了python基于搜索引擎實(shí)現(xiàn)文章查重功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • Python多線程與多處理之間的區(qū)別詳解

    Python多線程與多處理之間的區(qū)別詳解

    在本文中,我們將學(xué)習(xí) Python 中多線程和多處理的內(nèi)容、原因和方式,文中通過代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01
  • python比較2個(gè)xml內(nèi)容的方法

    python比較2個(gè)xml內(nèi)容的方法

    這篇文章主要介紹了python比較2個(gè)xml內(nèi)容的方法,涉及Python操作XML文件的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05

最新評(píng)論