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 ServicesHelloWorldWSDD (wsdl) hello add AdminService (wsdl) AdminService HelloWorldWSDDChain (wsdl) hello add HelloWorldWSDDHandler (wsdl) hello add Version (wsdl) getVersion4.测试客户程序如下:
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)
?
?
敬请老师们多帮忙....多谢多谢了..........