api是什么 api接口是干嘛的
2022-06-28 09:59:15 閱讀(244)
對于很多產(chǎn)品小白或求職者而言,API接口是一個產(chǎn)品和研發(fā)領(lǐng)域的專業(yè)術(shù)語,可能很多人平時接觸的很少,下面萬商云集小編給大家來詳細介紹一下api是什么 api接口是干嘛的這一塊的內(nèi)容,希望能幫助到大家。
本文目錄:
API接口是什么?
為什么我們需要API接口?
API接口的核心
一、API接口是什么?
我們來以一個常見的數(shù)學(xué)公式理解API,比如y=x+2,當(dāng)x=2的時候,y=4,對么?
那此時,我們把y=x+2稱為接口,x=2稱為參數(shù),y=4稱為返回結(jié)果,那這個接口的功能就是能把我們輸入的數(shù)加上2(注意:這里你可以發(fā)現(xiàn)接口自身是帶有邏輯的)。
類比地,我們來理解一個常見的場景,比如現(xiàn)在有一個可以把經(jīng)緯度轉(zhuǎn)化為城市的接口,那當(dāng)我輸入經(jīng)度是55°,緯度是88°的時候,接口通過自己的邏輯運算,返回結(jié)果告訴我:杭州市。
這樣你就可以清晰地了解百度百科的官方解釋了,接口就是預(yù)先定義的函數(shù)邏輯,他是供其他系統(tǒng)請求,然后返回結(jié)果的一個東西。
二、為什么我們需要API接口?
背景:我們的業(yè)務(wù)系統(tǒng)涉及多方多面,如果要一個公司或者一個系統(tǒng)把所有業(yè)務(wù)都做完,那未免工作量太大了吧?并且如果其他系統(tǒng)或公司有更好的運算邏輯,那我們在設(shè)計功能的時候可以考慮利用接口進行開發(fā)。
核心需求:利用現(xiàn)有接口可以降低開發(fā)成本,縮短開發(fā)成本。
舉個例子:比如我是打車的APP,現(xiàn)在我需要在我的頁面上展現(xiàn)地圖的功能,對于我司而言,新做地圖功能未免成本過高,那我們可以在高德開放平臺或者百度地圖的開放平臺,找到地圖API,這樣的話我們只需要購買高德的服務(wù),部署調(diào)用高德地圖API,這樣就可以快速在我們頁面上線地圖功能了。
三、API接口的核心
對于小白而言,初看API文檔可能是一頭霧水的——從哪里看,怎么看,看什么是擺在面前的問題。
其實對于產(chǎn)品經(jīng)理而言,我們應(yīng)該更關(guān)注這個公司可以提供什么樣的API接口服務(wù),比如我知道高德可以提供地圖API,規(guī)劃路線的API,這樣的話在我們設(shè)計功能和工作中就可以想到調(diào)用他們的服務(wù)或者參考。
所以產(chǎn)品小白們看不懂也不用過于擔(dān)心,未來工作中你也會更深入了解清楚,因為看懂并不復(fù)雜,以下是API接口的核心點,所有的說明文檔離不開這5個核心點。
以下說明均以微信開放平臺為例說明,文末有各開放平臺的地址,大家有空可以去學(xué)習(xí)。好了,事不宜遲,現(xiàn)在我們來建立一個場景。
我們現(xiàn)在有一個APP,需要用戶在購買的時候調(diào)起微信支付的API,完成購買。請各位自動進入這個場景,把自己當(dāng)作一位產(chǎn)品經(jīng)理。
1. 接口地址
現(xiàn)在Now,用戶點擊付款,我們需要告訴微信,我們要調(diào)起你們的收銀臺啦!但,去哪里告訴呢?這就需要接口地址了,也就相當(dāng)于向微信的這條鏈接傳輸指定的數(shù)據(jù)。
一個鏈接地址不是我們理解的一個頁面,你可以理解是一個電話號碼,小白們要改變這個觀念。
此時我們可以看到接口文檔告訴我們鏈接是如下這條,那我們現(xiàn)在已經(jīng)撥通微信的電話了。
2. 請求參數(shù)(報文)
我們現(xiàn)在需要告訴微信,你想調(diào)用收銀臺對吧。那我們需要寫下來,此時生成的叫做報文,也就是你想告訴這個接口的內(nèi)容是什么?相當(dāng)于前文函數(shù)的輸入x=2。
一般來說,報文的格式和內(nèi)容都是按接口文檔規(guī)定的。如下文就是微信開放平臺對調(diào)起收銀臺的報文要求。
我們先來看前2個參數(shù),你現(xiàn)在跟微信在對話,是不是應(yīng)該先告訴微信,你是誰?這里微信的文檔告訴你應(yīng)該要用應(yīng)用ID+商戶號來確定你的身份,什么意思呢?
比如你是A商戶,下面有a,b,c三個APP,所以微信要知道你是哪個商家,下面的哪個APP要用收銀臺。這是非常重要的,微信后面要把收到的錢打到對應(yīng)的賬戶以及統(tǒng)計數(shù)據(jù)等。
那我們就在報文里面寫下這兩句話:
wx2421b1c4370ec43b(我的應(yīng)用ID是wx2421…….)
10000100(我的商戶號是10000…….)
好了,現(xiàn)在微信知道你是誰了,那你要告訴微信,你需要微信支付幫你收多少錢對吧?這里定義了貨幣類型和總金額,也就是收什么貨幣,收多少錢。
這里你看,貨幣類型的必填寫了否,也就是說你也可以不告訴微信支付貨幣類型是什么,因為他在后面?zhèn)渥⒘四J(rèn)是人民幣。
好的,那我們寫下兩段報文
CNY(我要收人民幣)
1(我要收1元)
好了,現(xiàn)在微信知道你是誰,也知道要收多少錢了,那接下來微信支付要把收錢結(jié)果告訴你呀,因為你得知道用戶是成功支付了才能繼續(xù)發(fā)貨,服務(wù)啊等等的。所以這里我們用到通知地址,就是告訴微信,等下完事了他去哪里告訴你支付結(jié)果。那我們把地址寫好:
http://wxpay.wxutil.com/pub_v2/pay/notify.v2.php
3. 返回結(jié)果
剛剛微信支付已經(jīng)去收款了,現(xiàn)在他要在我們留下的通知地址中,告訴我們結(jié)果了。結(jié)果無非是兩種:成功收款?收款不成功?
(1)成功
很順利,現(xiàn)在用戶成功付錢了,并且微信也把成功的消息告訴我們了,并且他還把用戶支付的一些信息也告訴我們。
那這里就是微信支付成功收款后告訴我們的信息。
應(yīng)用APPID,商戶號:告訴你我成功扣款的是哪家商戶的哪個APPID的交易。
業(yè)務(wù)結(jié)果:成功或失敗
(2)失敗
在產(chǎn)品設(shè)計的時候,我們往往很關(guān)注失敗的情況,當(dāng)收款失敗的時候,微信同時會告訴你失敗的原因,如下圖很好理解,失敗的原因有很多很多種,我們在設(shè)計的時候往往要分析每種失敗的原因,為每個失敗的原因設(shè)計頁面和用戶提示,以確保用戶能理解。
以上就是api是什么 api接口是干嘛的的全部內(nèi)容,希望上面的內(nèi)容能幫助到大家理解到API這個技術(shù)知識,更多關(guān)于API的相關(guān)內(nèi)容請關(guān)注萬商云集。
- 本文關(guān)鍵詞:
- 電腦硬件