溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解輕量級的接口配置建??蚣躆idway-ModelProxy

發(fā)布時間:2021-11-17 14:20:06 來源:億速云 閱讀:110 作者:柒染 欄目:web開發(fā)

如何理解輕量級的接口配置建??蚣躆idway-ModelProxy,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

前言

使用Node做前后端分離的開發(fā)模式帶來了一些性能及開發(fā)流程上的優(yōu)勢(見《前后端分離的思考與實踐 一》), 但同時也面臨不少挑戰(zhàn)。在淘寶復雜的業(yè)務及技術架構下,后端必須依賴Java搭建基礎架構,同時提供相關業(yè)務接口供前端使用。Node在整個環(huán)境中最重要的工作之一就是代理這些業(yè)務接口,以方便前端(Node端和瀏覽器端)整合數(shù)據(jù)做頁面渲染。如何做好代理工作,使得前后端開發(fā)分離之后,仍然可以在流程上無縫銜接,是我們需要考慮的問題。本文將就該問題做相關探討,并提出解決方案。

如何理解輕量級的接口配置建??蚣躆idway-ModelProxy

由于后端提供的接口方式可能多種多樣,同時開發(fā)人員在編寫Node端代碼訪問這些接口的方式也有可能多種多樣。如果我們在接口訪問方式及使用上不做統(tǒng)一架構處理,則會帶來以下一些問題:

1. 每一個開發(fā)人員使用各自的代碼風格編寫接口訪問代碼,造成工程目錄及編碼風格混亂,維護相對困難。

2. 每一個開發(fā)人員編寫自己的mock數(shù)據(jù)方式,開發(fā)完畢之后,需要手工修改代碼移除mock。

3. 每一個開發(fā)人員為了實現(xiàn)接口的不同環(huán)境切換(日常,預發(fā),線上),可能各自維護了一些配置文件。

4. 數(shù)據(jù)接口調用方式無法被各個業(yè)務model非常方便地復用。

5. 對于數(shù)據(jù)接口的描述約定散落在代碼的各個角落,有可能跟后端人員約定的接口文檔不一致。

6. 整個項目分離開發(fā)之后,對于接口的聯(lián)調或者測試回歸成本依然很高,需要涉及到每一個接口提供者和使用者。

于是我們希望有這樣一個框架,通過該框架提供的機制去描述工程項目中依賴的所有外部接口,對他們進行統(tǒng)一管理,同時提供靈活的接口建模及調用方式,并且提供便捷的線上環(huán)境和生產(chǎn)環(huán)境切換方法,使前后端開發(fā)無縫結合。ModelProxy就是滿足這樣要求的輕量級框架,它是Midway Framework 核心構件之一,也可以單獨使用。使用ModelProxy可以帶來如下優(yōu)點:

1. 不同的開發(fā)者對于接口訪問代碼編寫方式統(tǒng)一,含義清晰,降低維護難度。

2. 框架內(nèi)部采用工廠+單例模式,實現(xiàn)接口一次配置多次復用。并且開發(fā)者可以隨意定制組裝自己的業(yè)務Model(依賴注入)。

3. 可以非常方便地實現(xiàn)線上,日常,預發(fā)環(huán)境的切換。

4. 內(nèi)置river-mock和mockjs等mock引擎,提供mock數(shù)據(jù)非常方便。

5. 使用接口配置文件,對接口的依賴描述做統(tǒng)一的管理,避免散落在各個代碼之中。

6. 支持瀏覽器端共享Model,瀏覽器端可以使用它做前端數(shù)據(jù)渲染。整個代理過程對瀏覽器透明。

7. 接口配置文件本身是結構化的描述文檔,可以使用river工具集合,自動生成文檔。也可使用它做相關自動化接口測試,使整個開發(fā)過程形成一個閉環(huán)。

ModelProxy工作原理圖及相關開發(fā)過程圖覽

如何理解輕量級的接口配置建??蚣躆idway-ModelProxy

在上圖中,開發(fā)者首先需要將工程項目中所有依賴的后端接口描述,按照指定的json格式,寫入interface.json配置文件。必要時,需要對每個接口編寫一個規(guī)則文件,也即圖中interface rules部分。該規(guī)則文件用于在開發(fā)階段mock數(shù)據(jù)或者在聯(lián)調階段使用River工具集去驗證接口。規(guī)則文件的內(nèi)容取決于采用哪一種mock引擎(比如 mockjs, river-mock 等等)。配置完成之后,即可在代碼中按照自己的需求創(chuàng)建自己的業(yè)務model。

下面是一個簡單的例子:

【例一】

  • ***步 在工程目錄中創(chuàng)建接口配置文件interface.json, 并在其中添加主搜接口json定義

{      "title": "pad淘寶項目數(shù)據(jù)接口集合定義",      "version": "1.0.0",      "engine": "mockjs",      "rulebase": "./interfaceRules/",      "status": "online",      "interfaces": [ {          "name": "主搜索接口",          "id": "Search.getItems",          "urls": {              "online": "http://s.m.taobao.com/client/search.do"         }      } ]  }
  • 第二步 在代碼中創(chuàng)建并使用model

// 引入模塊  var ModelProxy = require( 'modelproxy' );    // 全局初始化引入接口配置文件  (注意:初始化工作有且只有一次)  ModelProxy.init( './interface.json' );   // 創(chuàng)建model 更多創(chuàng)建模式請參后文  var searchModel = new ModelProxy( {      searchItems: 'Search.getItems'  // 自定義方法名: 配置文件中的定義的接口ID  } );   // 使用model, 注意: 調用方法所需要的參數(shù)即為實際接口所需要的參數(shù)。  searchModel.searchItems( { q: 'iphone6' } )      // !注意 必須調用 done 方法指定回調函數(shù),來取得上面異步調用searchItems獲得的數(shù)據(jù)!      .done( function( data ) {          console.log( data );      } )      .error( function( err ) {          console.log( err );      } );

ModelProxy的功能豐富性在于它支持各種形式的profile以創(chuàng)建需要業(yè)務model:

  • 使用接口ID創(chuàng)建>生成的對象會取ID***’.'號后面的單詞作為方法名

ModelProxy.create( 'Search.getItem' );

使用鍵值JSON對象>自定義方法名: 接口ID

ModelProxy.create( {      getName: 'Session.getUserName',      getMyCarts: 'Cart.getCarts' } );
  • 使用數(shù)組形式>取*** . 號后面的單詞作為方法名

下例中生成的方法調用名依次為: Cart_getItem, getItem, suggest, getName

ModelProxy.create( [ 'Cart.getItem', 'Search.getItem', 'Search.suggest', 'Session.User.getName' ] );
  • 前綴形式>所有滿足前綴的接口ID會被引入對象,并取其后半部分作為方法名

ModelProxy.create( 'Search.*' );

同時,使用這些Model,你可以很輕易地實現(xiàn)合并請求或者依賴請求,并做相關模板渲染

【例二】 合并請求

var model = new ModelProxy( 'Search.*' );   // 合并請求 (下面調用的model方法除done之外,皆為配置接口id時指定)  model.suggest( { q: '女' } )      .list( { keyword: 'iphone6' } )      .getNav( { key: '流行服裝' } )      .done( function( data1, data2, data3 ) {          // 參數(shù)順序與方法調用順序一致          console.log( data1, data2, data3 );      } );

【例三】 依賴請求

var model = new ModelProxy( {      getUser: 'Session.getUser',      getMyOrderList: 'Order.getOrder' } );  // 先獲得用戶id,然后再根據(jù)id號獲得訂單列表  model.getUser( { sid: 'fdkaldjfgsakls0322yf8' } )      .done( function( data ) {          var uid = data.uid;          // 二次數(shù)據(jù)請求依賴***次取得的id號          this.getMyOrderList( { id: uid } )              .done( function( data ) {                  console.log( data );              } );      } );

此外ModelProxy不僅在Node端可以使用,也可以在瀏覽器端使用。只需要在頁面中引入官方包提供的modelproxy-client.js即可。

【例四】瀏覽器端使用ModelProxy

<!-- 引入modelproxy模塊,該模塊本身是由KISSY封裝的標準模塊--> <script src="modelproxy-client.js" ></script>
<script type="text/javascript">      KISSY.use( "modelproxy", function( S, ModelProxy ) {          // !配置基礎路徑,該路徑與第二步中配置的攔截路徑一致!          // 且全局配置有且只有一次!          ModelProxy.configBase( '/model/' );           // 創(chuàng)建model          var searchModel = ModelProxy.create( 'Search.*' );          searchModel              .list( { q: 'ihpone6' } )              .list( { q: '沖鋒衣' } )              .suggest( { q: 'i' } )              .getNav( { q: '滑板' } )              .done( function( data1, data2, data3, data4 ) {                  console.log( {                      "list_ihpone6": data1,                      "list_沖鋒衣": data2,                      "suggest_i": data3,                      "getNav_滑板": data4                  } );              } );      } );  </script>

同時,ModelProxy可以配合Midway另一核心組件Midway-XTPL一起使用,實現(xiàn)數(shù)據(jù)和模板以及相關渲染過程在瀏覽器端和服務器端的全共享。

ModelProxy以一種配置化的輕量級框架存在,提供友好的接口model組裝及使用方式,同時很好的解決前后端開發(fā)模式分離中的接口使用規(guī)范問題。在整個項目開發(fā)過程中,接口始終只需要定義描述一次,前端開發(fā)人員即可引用,同時使用River工具自動生成文檔,形成與后端開發(fā)人員的契約,并做相關自動化測試,極大地優(yōu)化了整個軟件工程開發(fā)過程。

【注】River 是阿里集團研發(fā)的前后端統(tǒng)一接口規(guī)范及相關工具集合的統(tǒng)稱

關于如何理解輕量級的接口配置建??蚣躆idway-ModelProxy問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業(yè)資訊頻道了解更多相關知識。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI