`

Axis2创建webservice服务的方式 之 ADB 方式(二)

 
阅读更多

先参考 Axis2创建webservice服务的方式 之 ADB 方式(一)




2.5 wsdl2java生成的文件分析


由 http://jackyin5918.iteye.com/blog/1907992 这里知道:


在使用工具创建webservice服务文件框架后,要实现webservice服务,

就要修改生成的TestAdbSkeleton.java文件.因为这个文件仅仅是一个框架

里面的业务逻辑需要自己实现.

TestAdbSkeleton.java代码如下:


package test.adb.service;

/**
*  TestAdbSkeleton java skeleton for the axisService
*/
public class TestAdbSkeleton implements TestAdbSkeletonInterface
{

  public test.adb.theinterface.GetNameResponse getName(test.adb.theinterface.GetName getName0)
  {
    // TODO : fill this with the necessary business logic
    throw new java.lang.UnsupportedOperationException("Please implement " + this.getClass().getName() + "#getName");
  }

  public void setName(test.adb.theinterface.SetName setName2)
  {
    // TODO : fill this with the necessary business logic

  }
}

 
这个java类,跟之前的接口ITestAdb很类似,
只是 函数的返回值和参数变成了类似getName ,setName这种奇怪的类型.
这些类(getName ,setName)型是在wsdl中定义的type:

 

<wsdl:types>
    <xs:schema attributeFormDefault="qualified" elementFormDefault="qualified" targetNamespace="http://theinterface.adb.test">
            <xs:element name="setName">
                <xs:complexType>
                    <xs:sequence>
                        <xs:element minOccurs="0" name="args0" nillable="true" type="xs:string"/>
                    </xs:sequence>
                </xs:complexType>
            </xs:element>
            <xs:element name="getName">
                <xs:complexType>
                    <xs:sequence/>
                </xs:complexType>
            </xs:element>
            <xs:element name="getNameResponse">
                <xs:complexType>
                    <xs:sequence>
                        <xs:element minOccurs="0" name="return" nillable="true" type="xs:string"/>
                    </xs:sequence>
                </xs:complexType>
            </xs:element>
        </xs:schema>
  </wsdl:types>

 
因为webservice基于soap接口,在做数据交换时,使用xml传递数据.这样在调用webservice服务时,

  函数的返回值和方法参数都要变成一种特殊的格式,即,使用xml表示.

  比如,原来接口中 setName(Sring Name)方法 的参数 被定义成一种xml元素(setName)了,

  参数被定义为子元素 了,但是参数名称变成了arg0了,而不是原来的name(因为是自动生成的wsdl文件).

  当函数有返回值时,还会定义一种返回值类型,比如getNameResponse.

  在生成代码的时候,wsdl2java工具,将这些定义的类型都生成对应的Java类,比如getName,setName类型.

  定义好这种类型后,假如客户端请求服务,比如请求setName服务,那么客户端需要传递xml格式的参数,name,

  然后,服务器端收到xml的参数信息,并将xml信息转换成对应的setName类型的类对象,然后将这个对象传递给

  TestAdbSkeleton类的setName方法,做了相关处理后,完成客户端请求.

  当客户端请求的操作有返回值,比如getName,服务器端完成请求后,会返回结果,就是getNameResponse类型,

  客户端收到这个getNameResponse,在根据这个getNameResponse类型在wsdl中的定义,转换成xml格式,

  然后获取处理结果数据.


以算 setName这个类来分析:
SetName.java代码如下(部分):

public class SetName implements org.apache.axis2.databinding.ADBBean
{

  public static final javax.xml.namespace.QName MY_QNAME          
  = new javax.xml.namespace.QName("http://theinterface.adb.test", "setName", "ns1");

  /**
  * field for Args0
  */

  protected java.lang.String                    localArgs0;

  /*
   * This tracker boolean wil be used to detect whether the user called the set method for this attribute. It will be
   * used to determine whether to include this field in the serialized XML
   */
  protected boolean                             localArgs0Tracker = false;

  public boolean isArgs0Specified()
  {
    return localArgs0Tracker;
  }

  /**
  * Auto generated getter method
  * @return java.lang.String
  */
  public java.lang.String getArgs0()
  {
    return localArgs0;
  }

  /**
     * Auto generated setter method
     * @param param Args0
     */
  public void setArgs0(java.lang.String param)
  {
    localArgs0Tracker = true;

    this.localArgs0 = param;

  }

  /**
  *
  * @param parentQName
  * @param factory
  * @return org.apache.axiom.om.OMElement
  */
  public org.apache.axiom.om.OMElement getOMElement(final javax.xml.namespace.QName parentQName,
      final org.apache.axiom.om.OMFactory factory) throws org.apache.axis2.databinding.ADBException
  {

    org.apache.axiom.om.OMDataSource dataSource = new org.apache.axis2.databinding.ADBDataSource(this, MY_QNAME);
    return factory.createOMElement(dataSource, MY_QNAME);

  }
  
  //以下代码省略....
  
}

 

由以上代码可知,setName这个类型,实现了下面的接口.

public class SetName implements org.apache.axis2.databinding.ADBBean

这个接口干嘛的呢?

看代码:

 

public interface ADBBean
    extends Serializable
{

    public abstract XMLStreamReader getPullParser(QName qname)
        throws XMLStreamException;

    public abstract OMElement getOMElement(QName qname, OMFactory omfactory)
        throws ADBException;

    public abstract void serialize(QName qname, XMLStreamWriter xmlstreamwriter)
        throws XMLStreamException, ADBException;

    public abstract void serialize(QName qname, XMLStreamWriter xmlstreamwriter, boolean flag)
        throws XMLStreamException, ADBException;
}

 

有getArgs0()的方法,可以获取传递的参数.

 

还有个方法,public abstract OMElement getOMElement,这个是比较重要的方法.

返回的是OMElement类型,这个其实是表示xml的一个element,

比较特殊的是Axis2采用了一种比较特殊的解析xml的方法或者称之为模型,或者叫新型的xml解析引擎,

就是AXIOM,而OMElement就是AXIOM解析引擎解析出来的xml的element对象类型吧.

 

得到OMElement这个了,能干什么呢?

看看OMElement的api.

参考这个:http://ws.apache.org/axiom/apidocs/org/apache/axiom/om/OMElement.html

这里的api,就跟其他的xml的element一样,有一些getText,getAttribute神马的.

这样,在服务器端,通过OMElement这个就能得到客户端传来的数据了.

 

getName这个方法,需要返回一个getNameResponse,可以新建一个getNameResponsed对象,

然后调用getNameResponse对象的set_return方法,设置返回值.

 

于是,可以实现服务类了:

package test.adb.service;

import test.adb.theinterface.GetNameResponse;


/**
 *  TestAdbSkeleton java skeleton for the axisService
 */
public class TestAdbSkeleton implements TestAdbSkeletonInterface
{

  private String name = "Jack";
  public test.adb.theinterface.GetNameResponse getName(test.adb.theinterface.GetName getName0)
  {
    // TODO : fill this with the necessary business logic
    test.adb.theinterface.GetNameResponse gmr = new GetNameResponse();
    gmr.set_return(this.name);
    return gmr;
  }

  public void setName(test.adb.theinterface.SetName setName2)
  {
    // TODO : fill this with the necessary business logic
    String arg = setName2.getArgs0();
    this.name = arg;
  }
  
}

 

最后,调用ant,编译build.xml会生成TestWebService\build\lib\TestAdb.aar,使用该文件,即可完成webservice的部署.

例如,将上面的.aar文件部署到axis2自带的.war中时,可以通过下面的链接访问

http://localhost:8080/axis2/services/TestAdb/setName?args0=jjj

 

附件是工程(myeclipse 6.5),因为文件大小限制,删除了lib里面Axis1.6.2的jar包,需要补上.

 

遗留问题:

1. 自动生成的 wsdl文件,里面的 方法参数变成 args0这样的,不是原来接口中的方法名,这个能否自动纠正,还是需要手工修改自动生成的wsdl文件?

 

答案: 

写道
AXIS2默认生成的wsdl文件中所有的方法参数是args0,args1...等等;
要使wsdl文件中的方法参数显示为webservice接口中的实际的参数名称,
需要对webservice接口中的方法参数用@WebPara(name="参数名称")进行注解;
(提示: 是对接口定义的方法参数进行注解, 而不是对实现类的方法参数进行注解);
例如:webservice的认证接口定义:
public interface AuthService
{
public UserToken auth(@WebParam(name="userName") String userName, @WebParam(name="password") String password) throws ServiceException;
}

 

接口类:

package test.adb.theinterface;

import javax.jws.WebParam;

public interface ITestAdb
{
  void setName(@WebParam(name = "name") String name);
  String getName();
}

  自动生成的wsdl片段:

<xs:element name="setName">
                <xs:complexType>
                    <xs:sequence>
                        <!-- name属性改过来了变成name了 -->
                        <xs:element minOccurs="0" name="name" nillable="true" type="xs:string"/>
                    </xs:sequence>
                </xs:complexType>
            </xs:element>

 

 

参考: http://bbs.csdn.net/topics/390191801

 

2. wsdl里面service的location问题,是否写死了,部署到别的目录就不能访问了?

比如,上面的配置是

<http:address location="http://localhost:8080/axis2/services/TestAdb"/>

部署服务时,要是放到其他的目录中呢? 

 

问题2 参考: http://yuanlg.iteye.com/blog/1409906

分享到:
评论

相关推荐

    Axis2创建webservice服务的方式之POJO方式

    Axis2是Apache软件基金会开发的一个高效且灵活的Web服务引擎,它允许开发者用多种方式来创建Web服务,其中一种就是通过POJO(Plain Old Java Object)方式。这篇博文主要探讨了如何使用Axis2通过POJO方式构建Web服务...

    Axis2搭建WebService服务端demo

    在本文中,我们将深入探讨如何使用Spring、Axis2和Maven构建一个基于Java的Web服务(WebService)服务端示例。这些技术的结合为开发人员提供了高效、灵活且可扩展的解决方案来创建和消费Web服务。 首先,让我们了解...

    axis2包 使用axis2开发webservice需要的jar包

    在Java世界中,开发Web服务(Web Service)是一种常见的接口通信方式,Axis2是Apache软件基金会提供的一个开源工具,专门用于构建和部署Web服务。它基于SOAP(简单对象访问协议)标准,支持WS-*规范,提供了高效且...

    axis2;WebService

    【Axis2 WebService 开发指南】是关于使用Apache Axis2框架创建和操作Web服务的教程。Axis2是Axis1的升级版,提供了更多的功能和改进的性能。在开始之前,你需要下载并安装必要的开发工具,包括Axis2的jar包和...

    Axis2各种方式实现WebService案例代码

    Apache Axis2是Java平台上一个高效且灵活的Web服务框架,它允许开发者用多种方式创建和消费Web服务。本篇将深入探讨使用Axis2实现Web服务的五种主要方法:POJO、AXIOM、ADB、XMLBeans和JIBX,并涵盖客户端和服务器端...

    axis2+myeclipse开发webService

    Web服务的核心技术之一就是WebService,而Axis2是Apache软件基金会提供的一个高效、可扩展且灵活的Web服务引擎,常用于构建和部署Web服务。MyEclipse是一款强大的集成开发环境(IDE),特别适合Java EE项目的开发,...

    axis2之webservice

    标题中的“axis2之webservice”指的是Apache Axis2框架下的Web服务实现技术。Apache Axis2是Axis1的升级版,是一个高效、灵活且强大的Web服务引擎,用于创建和部署Web服务。它支持SOAP 1.1和1.2,以及RESTful Web...

    基于Axis2的WebService的实例demo(包含jar包)

    使用Axis2创建Web服务的第一步是编写服务接口和服务实现。接口定义了服务提供的操作,而实现则提供了具体的业务逻辑。例如,我们可以创建一个名为`HelloWorldService`的接口,其中包含一个`sayHello`方法,然后提供...

    axis2组建webservice,客户端必须的jar包

    本话题将详细阐述如何使用Axis2创建Java Web服务以及客户端在调用这些服务时所需的重要依赖库。 1. **Axis2组件**: - `axis2-kernel-1.5.jar`:这是Axis2的核心库,包含了Web服务的基础架构和处理机制。 - `axis...

    AXIS2发布WebService

    4. **配置AXIS2**:在AXIS2的配置文件(如`axis2.xml`)中,添加服务的部署信息,指定服务的位置和服务的传输方式(HTTP、HTTPS等)。 5. **部署服务**:将.aar文件放到AXIS2的部署目录下,AXIS2会自动检测并部署...

    axis2 + webService所需要的jar包

    标题“axis2 + webService所需要的jar包”指的是为了在项目中使用Axis2框架来实现Web服务,你需要包含一系列特定的Java类库(jar包)。这些jar包提供了 Axis2 和Web服务相关的功能支持。描述中的“已经简化了不必要...

    axis2访问WebService所需jar包

    在Java开发中,Axis2是一个广泛使用的Web服务框架,它基于Apache SOAP项目,提供了一种高效、灵活且可扩展的方式来创建和部署Web服务。本文将详细介绍标题为“axis2访问WebService所需jar包”的相关知识点,以及描述...

    Axis2 Webservice端例子

    二、 创建Axis2 Web服务 1. **定义服务接口**:首先,我们需要定义一个Java接口,该接口将作为Web服务的API。例如: ```java public interface HelloWorldService { String sayHello(String name); } ``` 2. **实现...

    axis实现webservice发布服务

    总结,使用Axis发布Web服务涉及到的主要步骤包括创建Java服务类、生成WSDL、部署服务、启动服务、生成客户端Stub、编写客户端代码并测试。了解这些步骤对于Java开发者在构建分布式系统和实现跨平台通信时至关重要。...

    WebService之Axis2实例

    WebService之Axis2实例是Web服务开发中的一个重要环节,它基于SOAP协议,允许不同平台和语言间的应用程序进行通信。本文将详细介绍Axis2实例的创建、配置和运行,以及如何利用Eclipse IDE、JDK 1.7和Tomcat 7.0进行...

    WebService-Axis2 详细讲解

    3. **服务部署**:Axis2支持多种部署方式,如AAR(Axis Archive)文件、WAR(Web Application Archive)文件或者直接通过代码部署。AAR文件是包含服务接口、实现和服务配置的特殊ZIP文件。 4. **传输协议**:Axis2...

    Axis2调用Webservice最全的Jar包

    里面包含axis2-adb-codegen-1.5.4.jar、axis2-java2wsdl-1.5.4.jar、axis2-transport-local-1.5.4.jar、mail-1.4.jar、woden-impl-dom-1.0M8.jar、XmlSchema-1.4.3.jar等十几个jar包

    收藏axis2的一本经书 axis2_WebService开发指南

    《Axis2 WebService开发指南》是一本专注于Java平台上的Web服务框架Axis2的权威书籍,适合于希望深入了解和使用Axis2进行Web服务开发的IT专业人士。Axis2是Apache软件基金会开发的一个高性能、灵活且可扩展的Web服务...

    axis2 开发webservice需要的完整jar

    在开发Web服务时,Axis2是一个非常流行的Java框架,它提供了高效且灵活的方式来创建和部署Web服务。本文将深入探讨Axis2的相关知识点,以及如何利用它与Spring框架进行整合。 一、Axis2简介 Axis2是Apache软件基金...

Global site tag (gtag.js) - Google Analytics