在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/Java/ 對接多個第三方API時,可使用到那幾種設(shè)計模式?

對接多個第三方API時,可使用到那幾種設(shè)計模式?

問題描述

因項目需要,要對接N個第三方API,再將請求API返回的數(shù)據(jù)轉(zhuǎn)換成自有項目的數(shù)據(jù)結(jié)構(gòu),第三個API有可能是一個已經(jīng)封裝好的SDK,有可能是一個URL,也有可能是restful風(fēng)格的API。

為了便于以后擴(kuò)展及維護(hù),大多數(shù)選用那幾種設(shè)計模式進(jìn)行開發(fā)會比較好?
現(xiàn)我想到的是抽象工廠及模板相結(jié)合,

用抽象工廠模式,將公用部分抽取出來實(shí)現(xiàn)
用模板模式,實(shí)現(xiàn)抽象方法

還有什么更好的,請討論。

回答
編輯回答
巷尾
  1. 策略模式
    首先,根據(jù)自有項目數(shù)據(jù)結(jié)構(gòu)和應(yīng)用場景,定義數(shù)據(jù)獲取的接口(每個場景對于一個接口,可能會有多個接口),從而將接口定義和具體實(shí)現(xiàn)分割。
  2. 模板方法
    對于不同的實(shí)現(xiàn)方式(SDK、URL、Restful)定義主流程,比如Restful主流程包括:
    a. 輸入?yún)?shù)驗(yàn)證
    b. 輸入?yún)?shù)到restful參數(shù)轉(zhuǎn)化(將接口輸入?yún)?shù),轉(zhuǎn)化給restful參數(shù))
    c. restful接口調(diào)用
    d. restful返回結(jié)果解析(成功、失敗)
    e. restful返回結(jié)果轉(zhuǎn)化(將結(jié)果轉(zhuǎn)化為自有數(shù)據(jù)結(jié)構(gòu))
  3. 整合(接口定義來自1,實(shí)現(xiàn)通用部分來自2,差異部分來自3)
    根據(jù)具體實(shí)現(xiàn)繼承自2創(chuàng)建的模板類,并實(shí)現(xiàn)1創(chuàng)建的業(yè)務(wù)接口,通過完成模板回調(diào)方法,完成整個業(yè)務(wù)。
  4. 其他
    如果有其他需要,比如統(tǒng)一日志、統(tǒng)一性能監(jiān)控,可以使用proxy模式
2018年7月6日 04:57
編輯回答
涼心人

根據(jù)你的描述我覺得可能這和設(shè)計模式?jīng)]有關(guān)系。
而應(yīng)該用分層設(shè)計。
比如典型的例子是:展示層,業(yè)務(wù)層,數(shù)據(jù)層。

  1. 展示層就負(fù)責(zé)接受請求,然后提供組裝好的數(shù)據(jù)返回。
  2. 業(yè)務(wù)層就處理數(shù)據(jù)的轉(zhuǎn)換組裝,和業(yè)務(wù)相關(guān)的計算等等。它從展示層獲得輸入,處理后傳給數(shù)據(jù)層,然后從數(shù)據(jù)層獲得返回,處理后再返回給展示層。
  3. 數(shù)據(jù)層就是你想要的封裝各種API的層,根據(jù)輸入不同它可以去不同的數(shù)據(jù)層的對象,比如SDK,restful,然后數(shù)據(jù)層負(fù)責(zé)和所有第三方API交互,業(yè)務(wù)層和展示層不需要知道第三方API的存在,數(shù)據(jù)層和第三方API交互后,獲得數(shù)據(jù),轉(zhuǎn)換成項目中的統(tǒng)一的數(shù)據(jù)結(jié)構(gòu),然后返回給業(yè)務(wù)層。

然后在數(shù)據(jù)層才會用到設(shè)計模式等,比如可以用工廠模式來創(chuàng)建不同的第三方服務(wù)。

2018年2月27日 09:55