級別: 初級
Vasudevan Thiyagarajan (vthiyaga@in.ibm.com), 系統(tǒng)工程師, IBM India Pvt. Ltd.
2007 年 3 月 20 日
了解如何從傳統(tǒng) Java 對象(Plain Old Java? Object,POJO)開發(fā)服務組件,并在 IBM? WebSphere Enterprise Service Bus 中發(fā)布。采用 Web 服務描述語言 (WSDL) 定義接口,并使用 Java? 實現(xiàn)。了解如何將服務組件與獨立引用相關聯(lián),以及如何使用獨立引用跨 ESB 訪問服務。
先決條件
本文假定您已經安裝了 IBM WebSphere ESB 6.0 和 IBM WebSphere Integration Developer 6.0。
WebSphere Enterprise Service Bus 簡介
WebSphere Enterprise Service Bus 是允許應用程序以靈活方式進行集成的平臺,可幫助企業(yè)實現(xiàn)其面向服務的體系結構(Service-Oriented Architecture,SOA)目標。ESB 允許服務使用者和服務提供者彼此進行交互,而其間沒有任何直接依賴關系。在 ESB 中,需要其他應用程序的服務的應用程序稱為“服務使用者”,而提供服務的應用程序稱為“服務提供者”。ESB 將服務使用者和服務提供者分離開,務必注意的是,您可以更改服務使用者或服務提供者的接口定義,而不用修改另一方。
WebSphere Enterprise Service Bus 能夠執(zhí)行以下主要任務,從而將服務提供者與服務使用者分離開來:
- 請求和響應路由:服務提供者和服務使用者之間的全部通信都以消息的形式進行。服務使用者請求服務,并針對 ESB 創(chuàng)建請求消息。ESB 平臺將充當提供者和使用者之間的傳輸媒介。ESB 將標識實際的服務提供者并將請求傳遞給提供者。服務提供者完成操作后,將以消息格式生成響應,并隨后將其返回給 ESB。ESB 將響應傳輸回實際的使用者。在整個通信過程中,提供者和使用者都不會意識到彼此的存在。只有 ESB 知道將請求和響應消息路由到何處。
- 消息轉換:ESB 允許提供者和使用者使用自己的協(xié)議和消息傳遞格式。他們并沒有必要遵循相同的協(xié)議和消息格式——ESB 將負責處理不同的協(xié)議和不同的消息格式。它知道如何將一種消息格式轉換為另一種消息格式,也知道如何將使用一種協(xié)議的消息轉換為使用另一種協(xié)議的消息。
下圖說明了 ESB 的角色:
圖 1. ESB 概略圖
在 WSDL 中創(chuàng)建接口
我們從將攝氏度轉換為華氏度的示例服務組件著手進行演示。Temperature Converter 組件具有名為 convert 的方法,該方法接受以攝氏度表示的給定溫度,并將返回對應的華氏度溫度作為輸出。我們將使用 JavaServer Pages (JSP) 客戶機進行測試,此客戶機通過獨立引用訪問該服務組件。
在 WebSphere ESB 中發(fā)布的每個服務組件都具有一個定義良好的接口。我們可以在 WebSphere Integration Developer 中為上述服務組件創(chuàng)建接口 TemperatureConverterInterface :
圖 2. 使用 New Java Interface Wizard 創(chuàng)建 WSDL 接口
如下所示,向上述接口添加具有一個輸入和一個輸出的請求與響應操作。此處的操作名為 convert,輸入為 Celsius as double ,輸出為 Fahrenheit as double 。
圖 3. 向接口添加操作
從 WSDL 通過 Assembly Editor 將服務組件作為 POJO 實現(xiàn)
接下來,我們?yōu)樯鲜鼋涌趧?chuàng)建一個傳統(tǒng) Java 對象 (POJO) 實現(xiàn)。我們可以在 Assembly Editor 的幫助下采用 Java 創(chuàng)建實現(xiàn)(服務組件),如下所示。Assembly Editor 屬于 WebSphere Integration Developer,允許開發(fā)人員通過接口(導入和導出)和綁定來連接 SCA 組件。我們將此實現(xiàn)命名為“TemperatureConverterImpl.java”。
圖 4. 使用 Assembly Editor 創(chuàng)建服務組件
接下來,我們需要通過“Add Interface”將接口 TemperatureConverterInterface 與此實現(xiàn)相關聯(lián)。
圖 5. 將接口與生成的服務組件相關聯(lián)
現(xiàn)在接口已與組件關聯(lián)。我們可以通過使用“Generate Implementation”選項生成實現(xiàn)的框架。
圖 6. 為新服務組件生成實現(xiàn)
圖 7. 將實現(xiàn)添加到生成的框架中
我們需要在上述類中添加 convert 方法的實現(xiàn),如下所示:
清單 1. Convert 方法實現(xiàn)
public Double convert(Double celsius) {
double dCelsius = celsius.doubleValue();
double fahr;
fahr = (((0.9/0.5) * dCelsius) + 32);
return new Double(fahr);
}
|
將服務組件與獨立引用關聯(lián)
接下來,我們將創(chuàng)建獨立引用,并將其與服務組件相關聯(lián),以便 JSP 客戶機能夠通過獨立引用訪問該組件。
圖 8. 創(chuàng)建獨立引用
我們可以通過“Add Reference”按鈕將 TemperatureConverterInterface.wsdl 與獨立引用相關聯(lián)。缺省情況下,獨立引用將被命名為 TemperatureConverterInterfacePartner 。
圖 9. 將獨立引用與服務組件連接
創(chuàng)建客戶機,并通過獨立引用訪問服務
接下來,我們需要開發(fā)客戶機 JSP 來測試服務組件。此 JSP 將允許用戶輸入攝氏度值。隨后 JSP 會將該值傳遞給服務,以將其轉換為華氏度,并最后顯示結果。
圖 10. 新 JSP 文件模板
將隨后使用下面所示的 ServiceManager 類通過 JSP 調用組件。
清單 2. JSP 實現(xiàn)
String cel = request.getParameter("celcius");
if(cel != null && cel.length() > 0){
try{
ServiceManager serviceManager = new ServiceManager();
Service service = (Service) serviceManager.locateService
("TemperatureConverterInterfacePartner");
Double celDouble = Double.valueOf(cel);
DataObject respObject = (DataObject) service.invoke("convert", celDouble);
if(respObject!= null){
out.println(respObject.getDouble("Fahrenheit"));
}
}catch(Exception e){
//handele it
}
}
|
打包并在 WebSphere ESB 中部署應用程序
組件和客戶機現(xiàn)在已經準備好,可以打包并在 WebSphere ESB 中部署,以便進行測試。將應用程序導出為 Integration Module EAR ,如下所示。
圖 11. 將項目作為集成模塊導出
圖 12. 集成模塊導出
在 WebSphere ESB 中通過 Admin Console 部署 EAR 文件,并在瀏覽器中訪問其“URL”。
圖 13. 最終輸出
結束語
通過本文,您已經了解了如何使用自底向上方法(從接口到實現(xiàn))創(chuàng)建服務組件以及如何在 IBM WebSphere ESB 中發(fā)布它。另外,還了解了如何通過獨立引用從客戶機訪問此服務組件。
|