axis2開發webservice之會話(Session)管理

 

axis2開發webservice之會話(Session)管理

分類: Web Service

       在看下面文章之前,可以看一下這一篇文章點擊打開鏈接,寫的非常好,是我在學習session管理的時候在網上看到的,就轉載來了。

      

       WebService給人最直觀的感覺就是由一個個方法組成,並在客戶端通過SOAP協議調用這些方法。這些方法可能有返回值,也可能沒有返回值。雖然這樣可以完成一些工具,但這些被調用的方法是孤立的,當一個方法被調用後,在其他的方法中無法獲得這個方法調用後的狀態,也就是說無法保留狀態。

讀者可以想象,這對於一個完整的應用程序,無法保留狀態,就意味着只依靠WebService很難完成全部的工作。例如,一個完整的應用系統都需要進行登錄,這在Web應用中使用Session來保存用戶登錄狀態,而如果用WebService的方法來進行登錄處理,無法保存登錄狀態是非常令人尷尬的。當然,這也可以通過其他的方法來解決,如在服務端使用static變量來保存用戶狀態,併發送一個id到客戶端,通過在服務端和客戶端傳遞這個id來取得相應的用戶狀態。這非常類似於Web應用中通過SessionCookie來管理用戶狀態。但這就需要由開發人員做很多工作,不過幸好Axis2爲我們提供了WebService狀態管理的功能。

使用Axis2來管理WebService的狀態基本上對於開發人員是透明的。在WebService類需要使用org.apache.axis2.context.MessageContextorg.apache.axis2.context.ServiceContext類來保存與獲得保存在服務端的狀態信息,這有些象使用HttpSession接口的getAttributesetAttribute方法獲得與設置Session域屬性。

除此之外,還需要修改services.xml文件的內容,爲<service>元素加一個scope屬性,該屬性有四個可取的值:Application, SOAPSession, TransportSession, Request,不過要注意一下,雖然Axis2的官方文檔將這四個值的單詞首字母和縮寫字母都寫成了大寫,但經筆者測試,必須全部小寫纔有效,也就是這四個值應爲:applicationsoapsessiontransportsessionrequest,其中requestscope屬性的默認值。讀者可以選擇使用transportsessionapplication分別實現同一個WebService類和跨WebService類的會話管理。

在客戶端需要使用setManageSession(true)打開Session管理功能。

綜上所述,實現同一個WebServiceSession管理需要如下三步:

1. 使用MessageContext和ServiceContext獲得與設置key-value對。

2. 爲要進行Session管理的WebService類所對應的<service>元素添加一個scope屬性,並將該屬性值設爲transportsession

3. 在客戶端使用setManageSession(true)打開Session管理功能。

下面是一個在同一個WebService類中管理Session的例子。

先建立一個WebService類,代碼如下:

[java] view plaincopy
  1. package session;  
  2.   
  3. import org.apache.axis2.context.ServiceContext;  
  4. import org.apache.axis2.context.MessageContext;  
  5. public class LoginService  
  6. {  
  7.     public boolean login(String username, String password)  
  8.     {  
  9.         if("bill".equals(username) && "1234".equals(password))  
  10.         {  
  11.             //  第1步:設置key-value對  
  12.             MessageContext mc = MessageContext.getCurrentMessageContext();  
  13.             ServiceContext sc = mc.getServiceContext();  
  14.             sc.setProperty("login""成功登錄");      
  15.             return true;  
  16.         }  
  17.         else  
  18.         {  
  19.             return false;  
  20.         }  
  21.     }  
  22.     public String getLoginMsg()  
  23.     {  
  24.         //  第1步:獲得key-value對中的value  
  25.         MessageContext mc = MessageContext.getCurrentMessageContext();  
  26.         ServiceContext sc = mc.getServiceContext();  
  27.         return (String)sc.getProperty("login");      
  28.     }  
  29. }  


 

LoginService類中有兩個方法:logingetLoginMsg,如果login方法登錄成功,會將“成功登錄”字符串保存在ServiceContext對象中。如果在login方法返回true後調用getLoginMsg方法,就會返回“成功登錄”。

下面是LoginService類的配置代碼(services.xml):

[html] view plaincopy
  1. <!--  第2步:添加scope屬性  -->  
  2. <service name="loginService" scope="transportsession">  
  3.     <description>  
  4.         登錄服務  
  5.         </description>  
  6.     <parameter name="ServiceClass">  
  7.         session.LoginService  
  8.         </parameter>  
  9.     <messageReceivers>  
  10.         <messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-out"  
  11.             class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />  
  12.     </messageReceivers>  
  13. </service>  

接下來就是生成stub類,目錄中生成了一個LoginServiceStub.java類,在該類中找到如下的構造句方法:

[java] view plaincopy
  1. public LoginServiceStub(org.apache.axis2.context.ConfigurationContext configurationContext,  
  2.         java.lang.String targetEndpoint, boolean useSeparateListener)  
  3.         throws org.apache.axis2.AxisFault   
  4. {  
  5.          
  6.     _serviceClient.getOptions().setSoapVersionURI(  
  7.                                  org.apache.axiom.soap.SOAP12Constants.SOAP_ENVELOPE_NAMESPACE_URI);  
  8. }  

在該方法中最後添加如下的代碼:

[java] view plaincopy
  1. //  第3步:打開客戶端的Session管理功能  
  2. _serviceClient.getOptions().setManageSession(true);  


在這個環節,由於stub類一般情況下都是上千行,所以我們可以使用快捷方式,ctrl+O來找方法,當然也可以用高級的ctrl+H

下面的客戶端代碼使用LoginServiceStub對象訪問了剛纔建立的WebService

[java] view plaincopy
  1. package session;  
  2.   
  3. import java.rmi.RemoteException;  
  4.   
  5. public class LoginStubClient {  
  6.   
  7.     public static void main(String[] args) throws RemoteException {  
  8.         LoginServiceStub lss = new LoginServiceStub();  
  9.         LoginServiceStub.GetLoginMsg glm = new LoginServiceStub.GetLoginMsg();  
  10.         LoginServiceStub.Login login = new LoginServiceStub.Login();  
  11.         login.setUsername("bill");  
  12.         login.setPassword("1234");  
  13.         if(lss.login(login).local_return){  
  14.             System.out.println(lss.getLoginMsg(glm).local_return);  
  15.         }  
  16.     }  
  17. }  

運行結果

上一篇:Axis2的session(會話)管理
發佈了13 篇原創文章 · 獲贊 8 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章