Axis_1.4中Chain特性异常

大体介绍一下环境:

写了一个简单的利用Axis_1.4的chain定制发布的小WS.

1.两个Handler,实现其invoke,并在该方法中记录访问该service的次数信息;

代码如下:

package com.test.wsddhandler;

import org.apache.axis.AxisFault;
import org.apache.axis.MessageContext;
import org.apache.axis.handlers.BasicHandler;

public class HelloWorldHandler extends BasicHandler {

 /**
  *
  */
 private static final long serialVersionUID = -3658682483583772974L;

 private static long count = 0l;
 
 private int reqCount = 0;
 
 public void invoke(MessageContext arg0) throws AxisFault {
  // TODO Auto-generated method stub

  count ++ ;
  reqCount ++ ;
  String status = (String) this.getOptions().get("status");
  System.out.println("HelloWorldHandler's status is : " + status + ",COUNT = " + count
    +" Handler Request Count = " + reqCount );
 }

}

package com.test.wsddchain;

import org.apache.axis.AxisFault;
import org.apache.axis.MessageContext;
import org.apache.axis.handlers.BasicHandler;

public class HelloWorldHandler2 extends BasicHandler{

 
 /**
  *
  */
 private static final long serialVersionUID = -2144111744853166634L;

 private static long count = 0l;
 
 private int reqCount = 0;
 
 public void invoke(MessageContext arg0) throws AxisFault {
  // TODO Auto-generated method stub

  count ++ ;
  reqCount ++ ;
  String status = (String) this.getOptions().get("status");
  System.out.println("HelloWorldHandler2's status is : " + status + ",COUNT = " + count
    +" Handler Request Count = " + reqCount );
 }

}

2.一个Chain,分别将两个Handler添加进来;

代码如下:

  package com.test.wsddchain;

import org.apache.axis.SimpleChain;

import com.test.wsddhandler.HelloWorldHandler;

public class HelloWorldChain extends SimpleChain {

 /**
  *
  */
 private static final long serialVersionUID = -2925126901439174032L;

 public HelloWorldChain() {
  // TODO Auto-generated constructor stub
 
  HelloWorldHandler handler = new HelloWorldHandler();
  HelloWorldHandler2 handler2 = new HelloWorldHandler2();
  
  this.addHandler(handler);
  this.addHandler(handler2);
 }
}

 

3.发布描述文件如下:

<deployment xmlns="http://xml.apache.org/axis/wsdd/"
 xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">  
 
 <chain name="HelloWorldChain">
  <handler type="java:com.sinosoft.wsddchain.HelloWorldChain"/>
 </chain>
 <service name="HelloWorldWSDDChain" provider="java:RPC">
  <requestFlow>
   <chain type="HelloWorldChain"/>
  </requestFlow>  
  <parameter name="className" value="com.sinosoft.wsdd.HelloWorldWSDD"/>  
  <parameter name="allowedMethods" value="*"/>
  <parameter name="scope" value="request"/> 
 </service>
   
</deployment> 

 

发布是没有问题的,

And now... Some Services

  • HelloWorldWSDD (wsdl)
    • hello
    • add
  • AdminService (wsdl)
    • AdminService
  • HelloWorldWSDDChain (wsdl)
    • hello
    • add
  • HelloWorldWSDDHandler (wsdl)
    • hello
    • add
  • Version (wsdl)
    • getVersion

4.测试客户程序如下:

package com.test.wsddchain;

import java.rmi.RemoteException;

import javax.xml.namespace.QName;
import javax.xml.rpc.ServiceException;

import org.apache.axis.client.Call;
import org.apache.axis.client.Service;

public class ClientWSDDChain {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  
  try {
   String url = "http://localhost:8080/axis/services/HelloWorldWSDDChain";
   Service serv = new Service();
   
   Call call = (Call) serv.createCall();
   call.setTargetEndpointAddress(url);
   
   call.setOperationName(new QName(url,"hello"));
   String result = (String) call.invoke(new Object[]{"wsdd chain"});
   System.out.println("result : " + result);
   
   call.setOperationName(new QName(url,"add"));
   Float resultVal = (Float) call.invoke(new Object[]{new Float(3.5),new Float(4.7)});
   System.out.println("add result : " + resultVal);
   
  } catch (ServiceException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (RemoteException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }

}

直接运行4,报以下的错误:

AxisFault
 faultCode: {http://xml.apache.org/axis/}Server
 faultSubcode:
 faultString: Server Error
 faultActor:
 faultNode:
 faultDetail:
 {http://xml.apache.org/axis/}stackTrace:Server Error
 at org.apache.axis.handlers.soap.SOAPService.invoke(SOAPService.java:474)
 at org.apache.axis.server.AxisServer.invoke(AxisServer.java:281)
 at org.apache.axis.transport.http.AxisServlet.doPost(AxisServlet.java:699)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
 at org.apache.axis.transport.http.AxisServletBase.service(AxisServletBase.java:327)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:228)
 at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
 at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
 at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
 at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
 at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:216)
 at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
 at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:634)
 at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:445)
 at java.lang.Thread.run(Thread.java:619)

 {http://xml.apache.org/axis/}hostname:test-3-zjl

Server Error
 at org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:222)
 at org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:129)
 at org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1087)
 at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(Unknown Source)
 at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown Source)
 at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source)
 at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
 at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
 at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
 at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(Unknown Source)
 at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(Unknown Source)
 at javax.xml.parsers.SAXParser.parse(Unknown Source)
 at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227)
 at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696)
 at org.apache.axis.Message.getSOAPEnvelope(Message.java:435)
 at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62)
 at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206)
 at org.apache.axis.client.Call.invokeEngine(Call.java:2784)
 at org.apache.axis.client.Call.invoke(Call.java:2767)
 at org.apache.axis.client.Call.invoke(Call.java:2443)
 at org.apache.axis.client.Call.invoke(Call.java:2366)
 at org.apache.axis.client.Call.invoke(Call.java:1812)
 at com.sinosoft.wsddchain.ClientWSDDChain.main(ClientWSDDChain.java:27)

 

 

敬请老师们多帮忙....多谢多谢了..........

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值