WebService大讲堂之Axis2(5):会话(Session)管理

WebService 给人最直观的感觉就是由一个个方法组成,并在客户端通过SOAP 协议调用这些方法。这些方法可能有返回值,也可能没有返回值。虽然这样可以完成一些工具,但这些被调用的方法是孤立的,当一个方法被调用后,在其他的方法中无法获得这个方法调用后的状态,也就是说无法保留状态。
读者可以想象,这对于一个完整的应用程序,无法保留状态,就意味着只依靠WebService 很难完成全部的工作。例如,一个完整的应用系统都需要进行登录,这在Web 应用中使用Session 来保存用户登录状态,而如果用WebService 的方法来进行登录处理,无法保存登录状态是非常令人尴尬的。当然,这也可以通过其他的方法来解决,如在服务端使用static 变量来保存用户状态,并发送一个id 到客户端,通过在服务端和客户端传递这个id 来取得相应的用户状态。这非常类似于Web 应用中通过Session Cookie 来管理用户状态。但这就需要由开发人员做很多工作,不过幸好Axis2 为我们提供了WebService 状态管理的功能。
使用Axis2 来管理WebService 的状态基本上对于开发人员是透明的。在WebService 类需要使用org.apache.axis2.context.MessageContext org.apache.axis2.context.ServiceContext 类来保存与获得保存在服务端的状态信息,这有些象使用HttpSession 接口的getAttribute setAttribute 方法获得与设置Session 域属性。
除此之外,还需要修改services.xml 文件的内容,为<service> 元素加一个scope 属性,该属性有四个可取的值: Application, SOAPSession, TransportSession, Request ,不过要注意一下,虽然Axis2 的官方文档将这四个值的单词首字母和缩写字母都写成了大写,但经笔者测试,必须全部小写才有效,也就是这四个值应为:application soapsession transportsession request ,其中request scope 属性的默认值。读者可以选择使用transportsession application 分别实现同一个WebService 类和跨WebService 类的会话管理。
在客户端需要使用setManageSession(true) 打开Session 管理功能。
综上所述,实现同一个WebService Session 管理需要如下三步:
1.  使用MessageContext ServiceContext 获得与设置key-value 对。
2.  为要进行Session 管理的WebService 类所对应的<service> 元素添加一个scope 属性,并将该属性值设为 transportsession
3.  在客户端使用setManageSession(true) 打开Session 管理功能。
下面是一个在同一个WebService 类中管理Session 的例子。

先建立一个WebService类,代码如下:

package  service;
import  org.apache.axis2.context.ServiceContext;
import  org.apache.axis2.context.MessageContext;
public   class  LoginService
{
    
public   boolean  login(String username, String password)
    {
        
if ( " bill " .equals(username)  &&   " 1234 " .equals(password))
        {
            
//   第1步:设置key-value对
            MessageContext mc  =  MessageContext.getCurrentMessageContext();
            ServiceContext sc 
=  mc.getServiceContext();
            sc.setProperty(
" login " " 成功登录 " );    
            
return   true ;
        }
        
else
        {
            
return   false ;
        }
    }
    
public  String getLoginMsg()
    {
        
//   第1步:获得key-value对中的value
        MessageContext mc  =  MessageContext.getCurrentMessageContext();
        ServiceContext sc 
=  mc.getServiceContext();
        
return  (String)sc.getProperty( " login " );    
    }
}
LoginService 类中有两个方法:login getLoginMsg ,如果login 方法登录成功,会将“成功登录”字符串保存在ServiceContext 对象中。如果在login 方法返回true 后调用getLoginMsg 方法,就会返回“成功登录”。
下面是LoginService 类的配置代码(services.xml ):
<!--   第2步:添加scope属性   -->
< service  name ="loginService"  scope ="transportsession" >
    
< description >
        登录服务
        
</ description >
    
< parameter  name ="ServiceClass" >
        service.LoginService
        
</ parameter >
    
< messageReceivers >
        
< messageReceiver  mep ="http://www.w3.org/2004/08/wsdl/in-out"
            class
="org.apache.axis2.rpc.receivers.RPCMessageReceiver"   />
    
</ messageReceivers >
</ service >
使用如下的命令生成客户端使用的stub 类:
%AXIS2_HOME%\bin\wsdl2java -uri http://localhost: 8080 /axis2/services/loginService?wsdl -p client -s -o stub
stub\src\client 目录中生成了一个LoginServiceStub.java 类,在该类中找到如下的构造句方法:
public  LoginServiceStub(org.apache.axis2.context.ConfigurationContext configurationContext,
        java.lang.String targetEndpoint, 
boolean  useSeparateListener)
        
throws  org.apache.axis2.AxisFault 
{
     
    _serviceClient.getOptions().setSoapVersionURI(
                                 org.apache.axiom.soap.SOAP12Constants.SOAP_ENVELOPE_NAMESPACE_URI);
}
在该方法中最后添加如下的代码:
//   第3步:打开客户端的Session管理功能
_serviceClient.getOptions().setManageSession( true );
下面的客户端代码使用LoginServiceStub 对象访问了刚才建立的WebService
LoginServiceStub stub  =   new  LoginServiceStub();
LoginServiceStub.Login login 
=   new  LoginServiceStub.Login();
login.setUsername(
" bill " );
login.setPassword(
" 1234 " );
if (stub.login(login).local_return)
{
    System.out.println(stub.getLoginMsg().local_return);
}
运行上面的代码后,会输出“成功登录”信息。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值