色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 消費電子 > 設計應用 > RFID中間件技術探秘

          RFID中間件技術探秘

          作者: 時間:2018-08-13 來源:網(wǎng)絡 收藏

          本文引用地址:http://cafeforensic.com/article/201808/386476.htm

          類的設計參見源代碼示例,從中可以看出,采用簡單工廠模式(Simple Factory)能夠在客戶端不知情的情況下,靈活地替換API實現(xiàn)類的版本。中間件API接口清晰地定義了中間件提供的操作,客戶端只須知道工廠類(APIFactory)能夠得到中間件API接口的實例即可。

          中間件API接口MiddlewareAPI:

          publicinterfaceMiddlewareAPI{

          void define(String specName, ECSpec spec);

          void undefine(String specName);

          void subscribe(String specName, String uri);

          void unsubscribe(String specName, String uri);

          EPCReports poll(String specName);

          EPCReports immediate(ECSpec spec);

          }

          工廠類APIFactory:

          publicclassAPIFactory{

          publicstaticMiddlewareAPIgetAPIInstance(){

          }

          }

          API的實現(xiàn)類A:

          publicclassClient{

          publicstaticvoidmain(String[] args) {

          MiddlewareAPI api = APIFactory.getAPIInstance();

          api.define(a new spec, new EPCSpec());

          }

          }

          3.3 狀態(tài)模式模擬規(guī)則的狀態(tài)機

          規(guī)則在其生命周期中擁有不同的狀態(tài),在每個狀態(tài)對一系列操作都有著不同的表現(xiàn),于是可以利用狀態(tài)模式(state)來模擬規(guī)則的狀態(tài)機,將不同狀態(tài)的不同表現(xiàn)作為可變化因素封裝起來,參見代碼示例。

          規(guī)則狀態(tài)接口ECState:

          publicinterfaceECState{

          voidsubscribe(StringspecName,String uri);

          voidunsubscribe(StringspecName,String uri);

          EPCReportspoll(StringspecName);

          }

          未被請求狀態(tài)類ECStateUnrequested:

          publicclassECStateUnrequestedimplements ECState {

          }

          已被請求狀態(tài)類ECStateRequested:

          publicclassECStateRrequestedimplements ECState {

          }

          激活狀態(tài)類ECStateActive:

          publicclassECStateActiveimplements ECState {

          }

          規(guī)則類ECSpec:

          publicclassECSpec{

          privateECStatestate;

          publicECStategetState(){

          return state;

          }

          publicvoidsetState(ECStatestate) {

          this.state = state;

          }

          }

          這樣,在針對規(guī)則實施相應操作的時候,就可以直接把相應操作委派給其狀態(tài)屬性(ECState)去做即可。比如,ECSpec的subscribe操作,只需一行代碼“state.suscribe(specName, uri);”即可。其中,specName、uri為臨時變量,具體取值在方法調(diào)用之前確定。

          由面向對象的多態(tài)性特征,根據(jù)state字段目前所指向的對象來動態(tài)確定由ECState接口的哪一個具體的實現(xiàn)類的代碼來完成工作。ECState接口的實現(xiàn)類根據(jù)實際情況確定是否需要在處理過程中修改ECSpec對象的狀態(tài)屬性(state),此處在應用狀態(tài)模式時,需要設計多個定時器類來輔助狀態(tài)機的跳轉。

          3.4 策略模式切換多種報告上傳、命令下發(fā)方式

          事件周期結束之后,中間件需要組裝報告上傳給規(guī)則的預訂者,即應用系統(tǒng)。上傳的方式有多種,如HTTP、Socket、JMS等等。中間件的核心邏輯處理模塊不應該關心具體的上傳技術,相應工作應交給報告上傳模塊來做,核心邏輯處理模塊只須完成自己的工作,然后把一定格式的數(shù)據(jù)通過報告上傳模塊發(fā)送,參見代碼示例。

          報告發(fā)送接口ReportSender:

          publicinterfaceReportSender{

          voidsendReport(ECReportsreports);

          }

          通過Http方式發(fā)送報告的ReportSender接口實現(xiàn)類ReportSenderByHttp:

          publicclassReportSenderByHttpimplements ReportSender {

          public void sendReport(ECReports reports) {

          }

          }

          通過Socket方式發(fā)送報告的ReportSender接口實現(xiàn)類ReportSenderBySocket:

          publicclassReportSenderBySocketimplements ReportSender {

          publicvoidsendReport(ECReportsreports) {

          }

          }

          通過JMS方式發(fā)送報告的ReportSender接口實現(xiàn)類ReportSenderByJms:

          publicclassReportSenderByJmsimplements ReportSender {

          publicvoidsendReport(ECReportsreports) {

          }

          }

          報告發(fā)送示例客戶端類

          SendReportWorker:

          publicclassSendReportWorker{

          privateReportSendersender;

          privateECReportsreports;

          publicvoidsetReports(ECReportsreports) {

          this.reports = reports;

          }

          publicstaticvoidmain(String[] args) {

          SendReportWorker worker = new

          SendReportWorker();

          worker.sender.sendReport(reports);

          }

          publicvoidsetSender(ReportSendersender) {

          this.sender = sender;

          }

          }

          這樣,發(fā)送消息的工人類可通過設置ReportSender的實例來靈活設置其發(fā)送方式。

          同樣,中間件的清點命令下發(fā),即中間件與閱讀器之間的接口,也存在多種方式,如Socket、SOAP等,也可采用類似的設計。

          3.5 觀察者模式處理上報消息

          閱讀器的消息上報轉換為消息對象,對消息對象的接收、分發(fā)可采用經(jīng)典的觀察者模式實現(xiàn)。

          4、中間件發(fā)展方向

          4.1 與閱讀器管理系統(tǒng)的融合

          中間件是閱讀器與后臺應用系統(tǒng)之間的橋梁,而閱讀器通常有設備管理需求,比如軟件版本下載、設備告警管理、參數(shù)配置等等,閱讀器管理系統(tǒng)也是直接與閱讀器交互的軟件模塊。于是,如何處理好中間件與閱讀器管理系統(tǒng)之間的關系成為一個亟待解決的問題。

          從軟件部署(部署在同一臺主機上)、軟件模塊重用(重用閱讀器通信模塊)等角度考慮,中間件與閱讀器管理系統(tǒng)的融合勢必成為中間件本身的一個優(yōu)勢。

          4.2 對多標準標簽的支持

          RFID技術在國內(nèi)外的發(fā)展和應用方興未艾,國際上多個標準組織都試圖統(tǒng)一RFID標準,但在一定的時期內(nèi),勢必出現(xiàn)多標簽并存的情況。于是,對多標準標簽的支持也是中間件系統(tǒng)的一個發(fā)展方向。

          4.3 對多廠商閱讀器的支持

          中間件與閱讀器之間的接口、通信方式以及信息格式,也無法做到統(tǒng)一標準。對多廠商閱讀器的支持、至少對少數(shù)幾家主流廠商的閱讀器的支持,已經(jīng)是對中間件所提出的基本要求。


          上一頁 1 2 下一頁

          關鍵詞:

          評論


          相關推薦

          技術專區(qū)

          關閉