產(chǎn)品必修課:接口文檔怎么用?

7 評論 17376 瀏覽 227 收藏 12 分鐘

編輯導(dǎo)讀:為了方便開發(fā)和產(chǎn)品溝通,便有了接口文檔。接口文檔大多時候是給開發(fā)看的,那么產(chǎn)品為什么要會看接口文檔呢?本文作者對此發(fā)表了自己的看法,一起來看看吧。

又到了周末,快樂開黑開始!阿宅興沖沖得找小伙伴上號,結(jié)果小伙伴爾康擺手:“等一下,我先開電腦噴下開發(fā)。”

阿宅一局酣戰(zhàn)之后,又來找到小伙伴:“好了沒?”“沒好,我被開發(fā)噴了,是我的需求bug,老板還罵我了,你看。”

為了讓小伙伴盡快上號,我們開始一起復(fù)盤:“這是關(guān)于基金購買流程的需求,我在這個地方需要先明確基金的委托類型,我問爺爺找爸爸終于把這個理清楚了,可以分為購買、贖回、定投。結(jié)果上線后才發(fā)現(xiàn)分類沒定義完整?!薄斑@玩意不是接口里寫得明明白白嗎?”

“?。。。〗涌谖臋n是個啥!我怎么從來沒看過!”

“你啊你,都做了半年理財產(chǎn)品了,竟然連這個都不知道。那本宅就大發(fā)慈悲教教你吧,記住明天給我一根冰糖葫蘆。”

一、什么是接口文檔?

首先,什么是接口?你可以把它簡單理解為一個函數(shù),你輸入x,它就會告訴你y。你無需知道這個函數(shù)的邏輯,只需要知道輸入什么樣的問題,會得到什么樣的答案就可以了。

但x怎么輸,會出現(xiàn)什么樣的y,就需要通過接口文檔來了解。就比如下圖的表格,當(dāng)你按照“輸入?yún)?shù)”輸入“委托方式”、“分支機(jī)構(gòu)”等參數(shù)時,這個接口就會告訴你“資產(chǎn)賬戶”是什么。

恒生統(tǒng)一接入平臺_周邊接口規(guī)范(期貨,期權(quán)_20210812).xls

二、產(chǎn)品為什么要能看懂接口文檔?

接口一般來講分為兩種:

  • 程序內(nèi)部的接口:方法與方法、模塊與模塊之間的交互,如登錄發(fā)帖,發(fā)帖就必須要登錄,如果不登錄不能發(fā)帖,發(fā)帖和登錄這兩個模塊之間就要有交互,就會拋出一個接口,進(jìn)行內(nèi)部系統(tǒng)調(diào)用。
  • 系統(tǒng)對外的接口:從別人的網(wǎng)站或服務(wù)器上獲取資源或信息,對方不會提供數(shù)據(jù)庫,只能提供一個寫好的方法來獲取數(shù)據(jù),如購物網(wǎng)站和第三方支付,購物網(wǎng)站支付時可選擇第三方支付方法,但第三方不會提供自己的數(shù)據(jù)庫給購物網(wǎng)站,只會提供一個接口,供購物網(wǎng)站進(jìn)行調(diào)用。

這便意味著開發(fā)的人甚至團(tuán)隊都不一樣,為了便于溝通,便有了接口文檔。從這里可以看出,接口文檔大多時候是給開發(fā)看的,那么產(chǎn)品為什么要會看這玩意呢?

首先,在迭代或依賴其他系統(tǒng)時,你能明確知道有哪些資源。例如下面這個關(guān)于微信菜單創(chuàng)建的接口,從這個接口的參數(shù)“type”的說明,我們就能清楚的知道,微信菜單能實(shí)現(xiàn)3種交互:一是直接點(diǎn)擊打開網(wǎng)頁;二是消息推送;三是跳轉(zhuǎn)小程序。

其次,業(yè)務(wù)很復(fù)雜的時候可以通過接口反推,例如我們在做期貨需求時,不清楚期貨產(chǎn)品分為哪些,這時我們便可以找到恒生的接口查查它的數(shù)據(jù)字典,結(jié)果就發(fā)現(xiàn)答案竟如此清晰:

再次,在寫需求文檔或和開發(fā)溝通發(fā)現(xiàn)說不明白時,也可以通過文檔來澄清。例如做內(nèi)容排序時可能有多個時間:創(chuàng)建時間、更新時間、操作時間等等。而你想調(diào)用的時間和開發(fā)理解的可能會存在差異,這時你便可拉出接口文檔告訴他我要的就是CreateTime。

當(dāng)然啦,接口文檔還有很多妙用,比如作為撕逼利器、裝逼神器等等,歡迎大家在留言區(qū)寫下你的文檔故事~

三、接口文檔怎么看?

接口文檔有這么多好處,那我們怎么去讀懂它呢?在這里我們用微信訂閱通知的接口文檔作為學(xué)習(xí)材料。

如上圖所示,接口通常分為四部分:請求方法、url、請求參數(shù)、返回參數(shù):

1)請求方法:常用的方法就是下面的四種——GET、PUT、POST、DELETE。

  • GET請求會向數(shù)據(jù)庫發(fā)索取數(shù)據(jù)的請求,從而來獲取信息。該請求就像數(shù)據(jù)庫的select操作一樣,只是用來查詢一下數(shù)據(jù),不會修改、增加數(shù)據(jù),不會影響資源的內(nèi)容,即該請求不會產(chǎn)生副作用。
  • 與GET不同的是,PUT請求是向服務(wù)器端發(fā)送數(shù)據(jù)的,從而改變信息。該請求就像數(shù)據(jù)庫的update操作一樣,用來修改數(shù)據(jù)的內(nèi)容,但是不會增加數(shù)據(jù)的種類等。
  • POST請求同PUT請求類似,都是向服務(wù)器端發(fā)送數(shù)據(jù)的,但是該請求會改變數(shù)據(jù)的種類等資源,就像數(shù)據(jù)庫的insert操作一樣,會創(chuàng)建新的內(nèi)容。目前所有的提交操作幾乎都是用POST請求。
  • DELETE請求顧名思義,就是用來刪除某一個資源的,該請求就像數(shù)據(jù)庫的delete操作。

這個概念產(chǎn)品經(jīng)理簡單了解即可,一般不考

2)url:以微信微信訂閱通知接口的url為例https://api.weixin.qq.com/wxaapi/newtmpl/addtemplate?access_token=ACCESS_TOKEN

我們可以把這個 URL 分解成 5部分:

  • 協(xié)議部分:指訪問服務(wù)器獲取資源時,需要使用哪種協(xié)議。常用的有http、https、ftp協(xié)議等。本例中的為https。
  • 域名部分:指資源宿主服務(wù)器的主機(jī)名或IP地址。本例中的域名部分為:api.weixin.qq.com。URL中也可以使用IP作為域名。
  • 端口部分:域名和端口之間使用“:“作為分隔符,端口不是一個URL必須的部分。http服務(wù)的默認(rèn)端口是80,這種情況下端口號可以省略,如果使用了其他端口必須知名,例如:http://www.azhai.com:90/。
  • 虛擬目錄部分:該部分說明了資源位于服務(wù)器的什么地方。從域名后的第一個“/“開始到最后一個“/“為止,是虛擬目錄部分。本例中的虛擬目錄是“/wxaapi/newtmpl/”。
  • 文件名部分:從域名的最后一個”/“開始到”?“為止,是文件名部分。如果沒有”?“,則是從域名后的最后一個“/”開始到“#”為止;如果沒有“?”和“#”,那么從域名后的最后一個“/”開始到結(jié)束,都是文件名部分。文件名部分也不是一個URL必須的部分,如果省略該部分,則使用默認(rèn)的文件名。本例中的文件名是“addtemplate”。

同樣,產(chǎn)品經(jīng)理不需要非常明白。

3)請求參數(shù)和返回參數(shù):請求參數(shù)和返回參數(shù)都分為:字段、說明、類型、默認(rèn)值、是否必填這5列。

字段:類的屬性

說明:中文釋義

類型:屬性的類型,只有String、Number、Object、Array四大類

備注:一些解釋語,或者寫簡單的示例

4)返回參數(shù),要分兩種情況討論:

只返回接口調(diào)用成功或者失敗:code、reason

返回參數(shù):字段、說明、類型、默認(rèn)值、是否必填

四、一些可供學(xué)習(xí)的網(wǎng)址

微信開放文檔

https://developers.weixin.qq.com/doc/offiaccount/Subscription_Messages/api.html

金融交易統(tǒng)一接入平臺

https://ufx.hs.net/

高德地圖API

http://lbs.amap.com/api/jsapi-v2/summary

 

作者:阿宅的產(chǎn)品筆記;公眾號:阿宅的產(chǎn)品筆記(PMZZnote)

本文由 @公眾號阿宅的產(chǎn)品筆記 原創(chuàng)發(fā)布于人人都是產(chǎn)品經(jīng)理。未經(jīng)許可,禁止轉(zhuǎn)載

題圖來自Unsplash,基于CC0協(xié)議

作者:阿宅的產(chǎn)品筆記;公眾號:阿宅的產(chǎn)品筆記

本文由 @阿宅的產(chǎn)品筆記 原創(chuàng)發(fā)布于人人都是產(chǎn)品經(jīng)理。未經(jīng)許可,禁止轉(zhuǎn)載。

題圖來自Unsplash,基于CC0協(xié)議。

該文觀點(diǎn)僅代表作者本人,人人都是產(chǎn)品經(jīng)理平臺僅提供信息存儲空間服務(wù)

更多精彩內(nèi)容,請關(guān)注人人都是產(chǎn)品經(jīng)理微信公眾號或下載App
評論
評論請登錄
  1. 看完了,還是不明白接口文檔怎么看

    來自吉林 回復(fù)
  2. 為啥接口文檔需要產(chǎn)品經(jīng)理來寫???

    來自廣東 回復(fù)
    1. 哈哈哈我也一臉懵逼,正常的話 是哪個崗位來寫呀?

      來自浙江 回復(fù)
    2. 后端寫,前端用;產(chǎn)品寫明白頁面上需要哪些參數(shù)怎么展示傳遞就行了,參數(shù)在接口里怎么命名,什么格式,數(shù)據(jù)用不用拼接前后端商量下就出來了

      來自北京 回復(fù)
    3. 仔細(xì)讀題《接口文檔怎么 用 》

      回復(fù)
  3. 內(nèi)容量很豐富,學(xué)到了。接口文檔的確是經(jīng)常出現(xiàn)的情況

    來自陜西 回復(fù)
  4. 學(xué)到了,很詳細(xì),清晰明確,把復(fù)雜的內(nèi)容系統(tǒng)化,達(dá)到高效傳達(dá)的目的

    來自中國 回復(fù)