Apache Tomcat 部署 Web service

 

1、工具和安裝 

 

構建第一個 Web service的第一步是選擇一個工具集。將使用的工具有: 

 

Apache SOAP  -- SOAP 的這個開放源碼 Java 實現包括對 SOAP 1.1 規範有用的子集的支援,並與現有的 Web service很好地集成。請至http://xml.apache.org/soap/index.html下載soap-bin-2.0.zip 

 

Apache Jakarta Tomcat  -- Java Web 伺服器還實現了主機 Apache SOAP 2.0 所需的Java servlets 2.2 API 規範。請至http://www.apache.org/dist/jakarta/jakarta-tomcat-4.0/release/v4.0.3/

 

下載Apache Jakarta Tomcat 4.0 

 

Apache Xerces XML Parser 1.2.3 --該開放源碼 XML 語法分析器實現大多數最新 XML規範,並由 Apache SOAP 2.0 使用。請至http://xml.apache.org/xerces-j/下載Xerces-J-bin-1.2.3.zip 

 

倘若將每個安裝檔案解壓縮到根目錄,應該得到如下所示的目錄結構。

 

\

 

\jakarta-tomcat-4.0

 

\lib - contains webserver.jar, servlet.jar, jasper.jar, parser.jar, jaxp.jar

 

\soap-2_0

 

\lib - contains soap.jar

 

\xerces-1_2_3 - contains xerces.jar

 

 

 

接下來要做的是將 Xerces  SOAP .jar 檔添加到類路徑,確保 xerces.jar 在前面。如果不這樣做,則 Apache SOAP 可能會發現錯誤的 XML .jar 文件,從而無法正確工作。在自己的系統上將以下兩項添加到類路徑中: 

C:\xerces-1_2_3\xerces.jar
C:\soap-2_0\lib\soap.jar

最後,必須通過編輯 \jakarta-tomcat-4.0\conf\server.xml 並在檔中現有項之後附加下所示的 項來配置 Tomcat,以便它自動檢測 Apache SOAP 子系統。將 docBase 屬性設置成指向 Apache SOAP webapps/soap 子目錄的完整路徑。 

 

 

 

 

 

 

 

   path="/soap"

 

   docBase="C:/soap-2_0/webapps/soap"

 

   reloadable="true">

 

 

 

 

 

現在我們已準備好開始構建第一個 Web service應用。 

 

2、啟動 Web 伺服器 

 

        在開始編寫自己的 Web service之前,讓我們啟動 Tomcat 並啟動 SOAP 歡迎頁面。至開始功能表點選strat Tomcat這將啟動在本地主機埠 8080 上運行的 Tomcat Web伺服器。 

應該看到如下圖的螢幕: 
 

 

然後啟動 Web流覽器並輸入URL http://127.0.0.1:8080/soap。這將啟動在編輯 Tomcat server.xml 檔時安裝到 /soap Apache SOAP。如果這些都正確,您將看到如下圖中打開的頁面 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

此時,關閉流覽器並停止 Tomcat。將在編寫了 Web service並準備部署之後再次重新啟動它們。 

 

下載 Web service範例 

 

        筆者已編寫一個簡單的Hello Web Service 服務程式,我們可下載範例壓縮檔HelloWebService.zip,將其解開後放至於/webapps之中後,開啟啟動 Tomcat 

 

部署 Web service 

 

        要部署 Hello Web Service 服務。然後在流覽器中輸入 URL 啟動 Web 流覽器並輸入 URL http://127.0.0.1:8080/HelloWebService/。然後在看到歡迎螢幕時單擊 Run the adminclient。應該看到如下圖的螢幕。 
 

 

該螢幕顯示一些允許我們部署、取消部署和列出 Tomcat/SOAP 系統中駐有服務的選項。如果單擊 List 選項,將看到沒有要開始的服務。要部署Hello Web Service服務,單擊Deploy 選項並如下圖所示填充欄位。

 

 

 

以下是 Deploy 螢幕中每個欄位的解釋: 

 

  • IDWeb service標識。在本例中,我們將服務標識設置成http://tempuri.org/HelloWebService

     

  • Scope:服務的啟動方式。Request 表示每一個請求都創建一個新的服務實例。其他可用的方式是 Session  Application 在本例中,我們將服務的啟動方式設為Session

     

  • Methods:要在 Web service中顯示的由空格定界的方法列表。請注意,這好象暗示Web service無法顯示兩個同名方法,但 SOAP 規範並不禁止這樣做。 在本例中,我們的Methodsget

     

  • ProviderWeb service的類型。Apache/SOAP 目前只支持 Java 類和 Bean 腳本,但以後的版本將肯定支持 EJB 和其他流行的元件類型。 在本例中,我們的將Web service的類型設為Java

     

  • Provider Class/StaticJava 類別的名稱。必須通過類路徑設置獲得該類。如果Static 為真,則假定方法為 Java 類上的靜態方法,否則將它們作為實例方法處理。 在本例中,我們將Java 類別的名稱設為HelloWebServiceStatic 設為false

     

        其他欄位與 Apache/SOAP 平臺的專有載入項 (add-on) 相關,本文不再贅述。 
輸入這些欄位之後,向下滾動並單擊視窗底部的 Deploy 按鈕。應該看到一個螢幕表明已經部署了服務。如果單擊 List 按鈕,則將看到列出的 Web service URN。單擊其鏈結,應該看到如下圖的訊息。

 

 

 

如上述所言,部署過程非常簡單明瞭。有關當前部署的服務的所有資訊都被 Tomcat/SOAP存儲到當前目錄中名為 DeployedServices.ds 的文件中。請耐心嘗試並閱讀它 -- 它包含一個序列化的 Java 散列表! 

 

測試 Web service範例 

 

        在流覽器中輸入 URL 啟動 Web 流覽器並輸入 URL http://localhost:8080/HelloWebService/sample/HelloWebService/TestClient.jsp。應該看到如下圖的螢幕。

 

 

 

 

 

點選「Methods」裡面get的鏈結,會在「Inputs」頁面出現「Invoke」以及「Clear」這兩個按鈕,按下「Invoke」按鈕之後,便會去呼叫我們建置好的Web Service,並且取得Hello Web Service。如圖下所示:

 

 

 

 

 

 

 

 

 

arrow
arrow
    全站熱搜

    白努力電腦日記 發表在 痞客邦 留言(0) 人氣()