`
liangz
  • 浏览: 76899 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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)

 

 

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

分享到:
评论

相关推荐

    axis_1.4 for webservice 开发

    【描述】提到的"Attached the file is Axis_1.4 for webservice development,you can upload it and use it."意味着提供的压缩包包含了Axis 1.4的完整版本,用户可以将其上传到自己的开发环境中,并开始利用这个工具...

    axis_1.4 api文档

    9. **故障处理与调试**:理解Axis 1.4中的异常处理机制和日志记录对于问题排查至关重要。开发者需要知道如何阅读和分析错误信息,以及如何启用更详细的日志记录。 10. **部署配置**:Axis 1.4的部署文件(如axis-...

    Axis_1.4文档

    版本 1.4 是 Axis 的一个重要里程碑,提供了许多改进和特性,以支持 Java 和 SOAP(简单对象访问协议)的 Web 服务交互。在本文中,我们将深入探讨 Axis 1.4 的核心概念、功能和使用方法。 **1. Web 服务基础** ...

    web service AXIS2_1.4

    在"AXIS2_1.4"中,我们能找到以下关键知识点: 1. **模块化架构**:Axis2采用了模块化的架构,将服务分解为可重用的单元,称为“服务组件”。这种设计允许开发者按需加载和卸载服务,提高了灵活性和可维护性。 2. ...

    axis-src-1_4.zip_axis 1 source_axis 1.4_axis src 1_axis-src_axis

    标题中的"axis-src-1_4.zip_axis 1 source_axis 1.4_axis src 1_axis-src_axis"指的是Axis 1.4的源代码压缩包,这是一个与Java XML Web服务处理相关的开源项目。Axis是Apache软件基金会开发的一个SOAP(简单对象访问...

    axis1.3_1.4.rar

    Axis是Apache软件基金会开发的一个开源Web服务框架,主要用于构建和部署SOAP(Simple Object Access Protocol)服务。...同时,理解Axis的基本功能和版本差异,有助于在实际开发中更有效地利用这一工具。

    axis-bin-1_4.zip_Axis1.4-bin_axis 1.4_axis-1_4.rar_axis-bin-_axi

    在标题和描述中提到的"axis-bin-1_4.zip"和"Axis1.4-bin"是指 Axis 1.4 的二进制发行版,这个版本的AXIS包含了运行和开发Web服务所需的所有必要组件。"axis-1_4.rar"可能是同一版本的另一种压缩格式,而"axis-bin-_...

    axis-kickstart.rar_Home Home_axis_axis 1.4_axis tomcat_org.apach

    本文中使用的是JDK 5.0(源代码是1.4 的)。Tomcat 是5.0.28。 下载AXIS 1.4,地址http://ws.apache.org/ 安装AXIS 解压开axis1_ 4.zip ,将axis1_ 4/webapps/axis 拷贝到 $TOMCAT_HOME/webapps/ 下启动tomcat,打开...

    axis-1.4.jar

    在Java开发中,使用Axis-1.4.jar可以帮助开发者快速地创建客户端和服务端的Web服务。以下是这个库包含的一些关键知识点: 1. **Web服务客户端**:Axis提供了生成Java客户端代码的能力,这些代码可以直接调用远程Web...

    axis1.4完整包下载

    标题“axis1.4完整包下载”表明我们关注的是Apache Axis的1.4版本,这是一个较早但仍然在某些环境中使用的版本。 在描述中提到,“包含Axis1.4的所有完整包”,这意味着下载包中包含了运行和开发SOAP Web服务所需的...

    Axis-1.4开发工具

    在本文中,我们将深入探讨Axis-1.4开发工具及其相关知识点。 1. **SOAP和Web服务**: SOAP是一种基于XML的消息传递协议,用于在Web上交换结构化和类型化的信息。Web服务则是一种通过HTTP协议进行通信的应用程序...

    springboot+axis1.4

    2. **集成 Axis1.4**:首先,你需要在Spring Boot的`pom.xml`文件中添加Axis1.4的依赖。这通常意味着你需要手动添加Axis的库,因为Spring Boot默认并不包含对Axis的支持。你需要找到Axis1.4的Maven坐标,并在`...

    axis1.4生成客户端

    - JAX-WS(Java API for XML Web Services):这是Java平台标准,用于创建和处理Web服务,它是Axis2的替代品,相比Axis1.4更现代,支持更多特性。 通过理解上述内容,开发者能够有效地利用Axis1.4生成Web服务的...

    axis-1.4_1.jar.zip

    标题 "axis-1.4_1.jar.zip" 暗示了这是一个包含Axis 1.4版本源码的压缩文件,轴(Axis)是Apache软件基金会的一个开源项目,主要用于构建Web服务。它是一个SOAP(简单对象访问协议)引擎,允许开发者在Java平台上...

    Axis1.4_开发指南

    Axis1.4开发指南是一份针对使用Axis1.4版本开发WebService的详尽文档,它介绍了WebService的基本概念、Axis框架的安装与使用、WebService开发和部署的关键技术,以及如何处理复杂对象传递、异常和文件传递等高级特性...

    axis1.4帮助文档

    8. **异常处理**:在出现错误时,Axis1.4会抛出相应的SOAP异常,这有助于调试和问题定位。 9. **部署描述符**:Axis1.4使用`services.xml`和`deploy.wsdd`等部署描述符文件来配置服务和客户端的行为。这些文件提供...

    axis1.4依赖包

    在Axis1.4中,`mail.jar`和`activation-1.1.jar`是两个关键的依赖库,它们在Web服务通信中扮演着重要角色。 1. **mail.jar**: 这个JAR文件包含了JavaMail API,是一个用于处理电子邮件的开放源代码API。在Web服务中...

    axis-1.4.jar包下载

    android 移动开发 jar包 下载

    在axis1.4中传递复杂类型数组参数(ArrayMapping)

    在 Axis1.4 中传递复杂类型数组参数,涉及到的是 Web 服务中的数据绑定和消息处理。Axis 是一个开源的 SOAP 库,它允许开发者创建、部署和使用 Web 服务。在处理复杂类型数组时,ArrayMapping 是 Axis 中的一个关键...

    axis2 1.4 API HTML版

    在1.4版本中,它提供了一整套工具和API,帮助开发者实现基于SOAP(简单对象访问协议)的服务。本文将详细讲解Axis2 1.4 API及其HTML版的特点和主要功能。 1. **Web服务框架** Axis2是Apache CXF项目的一部分,作为...

Global site tag (gtag.js) - Google Analytics