Webhook是一個(gè)API概念,簡(jiǎn)單來(lái)說(shuō)就是一種反向API機(jī)制治宣,類似于觸發(fā)器的一樣急侥。
近幾年Webhook在前后端對(duì)接的開發(fā)模式中變得越來(lái)越流行,我們能用事件描述的事物越多侮邀,Webhook的作用范圍也就越大坏怪。Webhook作為一個(gè)輕量的事件處理應(yīng)用,正變得越來(lái)越實(shí)用绊茧。
下面我們來(lái)模擬場(chǎng)景:
在傳統(tǒng)的web server設(shè)計(jì)中铝宵,項(xiàng)目A想要獲取項(xiàng)目B的數(shù)據(jù),通常項(xiàng)目B需要提供一個(gè)API华畏,然后項(xiàng)目A去請(qǐng)求項(xiàng)目B的API鹏秋,從而獲得數(shù)據(jù)。
接下來(lái)新增了一個(gè)需求唯绍,項(xiàng)目A需要實(shí)時(shí)獲取到項(xiàng)目B的最新數(shù)據(jù)拼岳。
在傳統(tǒng)做法中,我們需要不停的去向項(xiàng)目B做輪詢操作况芒,以便獲取到最新數(shù)據(jù)惜纸,這樣的效率非常低,但是如果通過(guò)Webhook機(jī)制來(lái)設(shè)計(jì)的話绝骚,則可以變手動(dòng)為自動(dòng)耐版。
傳統(tǒng)做法:項(xiàng)目A需要不停輪詢?nèi)ダ№?xiàng)目B的最新數(shù)據(jù),即項(xiàng)目A -> 項(xiàng)目B
使用Webhook:項(xiàng)目A提供一個(gè)webhook url压汪,每次項(xiàng)目B創(chuàng)建新數(shù)據(jù)時(shí)粪牲,便會(huì)向項(xiàng)目A的hook地址進(jìn)行請(qǐng)求,項(xiàng)目A收到項(xiàng)目B的請(qǐng)求止剖,然后對(duì)數(shù)據(jù)進(jìn)行處理腺阳,即項(xiàng)目B -> 項(xiàng)目A
用一張圖來(lái)說(shuō)明,這個(gè)流程
如何使用Webhook?
使用webhook就需要為對(duì)應(yīng)的服務(wù)端編寫hook腳本穿香,再設(shè)計(jì)一個(gè)hook url亭引,用于接收服務(wù)端的請(qǐng)求。
通常webhook請(qǐng)求過(guò)來(lái)的數(shù)據(jù)格式為xml和json兩種皮获,在現(xiàn)代Web應(yīng)用中焙蚓,都能很好的解析和對(duì)這兩種數(shù)據(jù)進(jìn)行交互。
主要應(yīng)用場(chǎng)景
都常應(yīng)用于異步編程中,如:高安全的支付购公、微信登錄(OAuth)萌京、資源同步、資源創(chuàng)建與更新等宏浩。
場(chǎng)景:
你需要上傳一個(gè)視頻知残,獲得視頻處理后的結(jié)果,但是要上傳的視頻很多绘闷,在排隊(duì)進(jìn)行處理橡庞,沒法立刻獲取到視頻的處理結(jié)果。此時(shí)你可以設(shè)計(jì)一個(gè)hook url印蔗,當(dāng)視頻處理完成后服務(wù)器自動(dòng)向你的hook url發(fā)送通知扒最,告訴你視頻已經(jīng)處理完畢。
安全問(wèn)題
由于webhook會(huì)向公網(wǎng)上的hook url發(fā)送數(shù)據(jù),這就意味著某些不好心的人可能會(huì)找到這個(gè)url,從而進(jìn)行發(fā)送錯(cuò)誤的數(shù)據(jù),但是我們可以通過(guò)以下一些技術(shù)手段來(lái)解決這個(gè)問(wèn)題:
? 增加token機(jī)制
? 增加auth認(rèn)證
? 只接收對(duì)應(yīng)服務(wù)端domain或IP請(qǐng)求
? 數(shù)據(jù)簽名
需要注意的問(wèn)題
當(dāng)我們使用web hook需要特別注意的問(wèn)題
- 當(dāng)服務(wù)提供者通過(guò)web hook將數(shù)據(jù)發(fā)送你的服務(wù)端后华嘹,就不會(huì)再去關(guān)注這些數(shù)據(jù)吧趣。假設(shè)你的服務(wù)端此時(shí)出現(xiàn)了崩潰,或者無(wú)法請(qǐng)求成功等情況耙厚,就需要主動(dòng)去嘗試請(qǐng)求數(shù)據(jù)强挫。
- webhook會(huì)發(fā)出大量的請(qǐng)求,可能會(huì)造成你的應(yīng)用阻塞薛躬,在此需要確保你的應(yīng)用能夠處理好這些請(qǐng)求俯渤。
工具推薦
這里推薦的工具是Eolinker,webhook功能支持對(duì)接市面上絕大部分系統(tǒng)和工具型宝,服務(wù)支持的效率也挺高的八匠,用起來(lái)挺舒服的。
使用地址:www.eolinker.com