1. ADB方式生成webservice服务的流程:
(1)首先需要一个wsdl文件.
这个文件可以自己手写,或者从第三方获取,或者自己写一个interface,
然后使用Axis2的Java2wsdl工具生成.
(2) 根据(1)中wsdl文件,使用Axis2的wsdl2java工具生成服务的骨架文件
(还包含发布服务的services.xml文件,已经ant编译脚本文件build.xml等)
(3) 修改 wsdl2java工具生成的文件,发布服务.
2. 以ADB方式创建服务
2.1 先编写一个interface文件,如下:
package test.adb.theinterface; public interface ITestAdb { void setName(String name); String getName(); }
接口文件放到test.adb.theinterface包中.
2.2 使用axis的java2wsdl方式生成wsdl文件.
以工程的calss目录为当前目录
(比如 web程序一般以WEB-INF\classes为当前目录,因为-cn表示类名,该类名需要包含完整的包名
且改命令需要找到.class文件),
执行命令:
%AXIS2_HOME%\bin\java2wsdl -o build -of TestAdb.wsdl -sn TestAdb -cn test.adb.theinterface.ITestAdb
-o build 表示在当前文件夹下面,新建一个build文件夹,生成的wsdl文件放到这个build文件夹下面
-of TestAdb.wsdl 指定生成的wsdl文件名为TestAdb.wsdl
-sn TestAdb 表示服务名称为TestAdb
-cn 表示类名,需要完整包名
%AXIS2_HOME%中的AXIS2_HOME是事先创建的指向axis2版本根目录的环境变量.
命令参数详情参考: http://jackyin5918.iteye.com/blog/1908559
执行上面的命令后,就得到了下面的wsdl文件:
<?xml version="1.0" encoding="UTF-8"?> <wsdl:definitions xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:ns1="http://org.apache.axis2/xsd" xmlns:ns="http://theinterface.adb.test" xmlns:wsaw="http://www.w3.org/2006/05/addressing/wsdl" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" targetNamespace="http://theinterface.adb.test"> <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> <wsdl:message name="getNameRequest"> <wsdl:part name="parameters" element="ns:getName"/> </wsdl:message> <wsdl:message name="getNameResponse"> <wsdl:part name="parameters" element="ns:getNameResponse"/> </wsdl:message> <wsdl:message name="setNameRequest"> <wsdl:part name="parameters" element="ns:setName"/> </wsdl:message> <wsdl:portType name="TestAdbPortType"> <wsdl:operation name="getName"> <wsdl:input message="ns:getNameRequest" wsaw:Action="urn:getName"/> <wsdl:output message="ns:getNameResponse" wsaw:Action="urn:getNameResponse"/> </wsdl:operation> <wsdl:operation name="setName"> <wsdl:input message="ns:setNameRequest" wsaw:Action="urn:setName"/> </wsdl:operation> </wsdl:portType> <wsdl:binding name="TestAdbSoap11Binding" type="ns:TestAdbPortType"> <soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/> <wsdl:operation name="getName"> <soap:operation soapAction="urn:getName" style="document"/> <wsdl:input> <soap:body use="literal"/> </wsdl:input> <wsdl:output> <soap:body use="literal"/> </wsdl:output> </wsdl:operation> <wsdl:operation name="setName"> <soap:operation soapAction="urn:setName" style="document"/> <wsdl:input> <soap:body use="literal"/> </wsdl:input> </wsdl:operation> </wsdl:binding> <wsdl:binding name="TestAdbSoap12Binding" type="ns:TestAdbPortType"> <soap12:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/> <wsdl:operation name="getName"> <soap12:operation soapAction="urn:getName" style="document"/> <wsdl:input> <soap12:body use="literal"/> </wsdl:input> <wsdl:output> <soap12:body use="literal"/> </wsdl:output> </wsdl:operation> <wsdl:operation name="setName"> <soap12:operation soapAction="urn:setName" style="document"/> <wsdl:input> <soap12:body use="literal"/> </wsdl:input> </wsdl:operation> </wsdl:binding> <wsdl:binding name="TestAdbHttpBinding" type="ns:TestAdbPortType"> <http:binding verb="POST"/> <wsdl:operation name="getName"> <http:operation location="getName"/> <wsdl:input> <mime:content type="application/xml" part="parameters"/> </wsdl:input> <wsdl:output> <mime:content type="application/xml" part="parameters"/> </wsdl:output> </wsdl:operation> <wsdl:operation name="setName"> <http:operation location="setName"/> <wsdl:input> <mime:content type="application/xml" part="parameters"/> </wsdl:input> </wsdl:operation> </wsdl:binding> <wsdl:service name="TestAdb"> <wsdl:port name="TestAdbHttpSoap11Endpoint" binding="ns:TestAdbSoap11Binding"> <soap:address location="http://localhost:8080/axis2/services/TestAdb"/> </wsdl:port> <wsdl:port name="TestAdbHttpSoap12Endpoint" binding="ns:TestAdbSoap12Binding"> <soap12:address location="http://localhost:8080/axis2/services/TestAdb"/> </wsdl:port> <wsdl:port name="TestAdbHttpEndpoint" binding="ns:TestAdbHttpBinding"> <http:address location="http://localhost:8080/axis2/services/TestAdb"/> </wsdl:port> </wsdl:service> </wsdl:definitions>
2.3 根据wsdl文件生成webservice服务代码骨架
通过 wsdl2java命令,生成骨架代码:
%AXIS2_HOME%\bin\wsdl2java -uri build/TestAdb.wsdl -p test.adb.service -d adb -s -ss -sd -ssi -o build\code
-uri build/TestAdb.wsdl 指定wsdl文件
-p 指定生成的代码 所在的包名
-d adb 指定绑定方式为 adb, 合法的方式为adb, xmlbeans, jibx and jaxbri (Default: adb).
-s 指创建代码使用 同步方式(阻塞方式)
-ss 指创建服务端代码骨架
-sd 指定需要创建services.xml
-ssi 指给服务代码java类创建一个interface
-o 指定生成文件的存放目录
2.4 将生成的代码拷贝到工程目录中.
生成的代码文件目录结构如下,
将resources, src 文件夹和build.xml文件拷贝到 web工程的根目录下,
这里的web工程时TestWebService,
所以将上面的resources, src 文件夹和build.xml文件都拷贝到TestWebService目录下.
拷贝后目录结构如下:
只关注展开的两个包即可.可以看到生成的文件.
相关推荐
Axis2是Apache软件基金会开发的一个Web服务引擎,它允许开发者以简单且高效的方式创建和部署Web服务。本篇将详细介绍使用Axis2通过ADB(Abstract Data Binding)方式创建Web服务的方法。 ADB,全称Abstract Data ...
Axis2是Apache软件基金会开发的一个高效且灵活的Web服务引擎,它允许开发者用多种方式来创建Web服务,其中一种就是通过POJO(Plain Old Java Object)方式。这篇博文主要探讨了如何使用Axis2通过POJO方式构建Web服务...
在本文中,我们将深入探讨如何使用Spring、Axis2和Maven构建一个基于Java的Web服务(WebService)服务端示例。这些技术的结合为开发人员提供了高效、灵活且可扩展的解决方案来创建和消费Web服务。 首先,让我们了解...
在Java世界中,开发Web服务(Web Service)是一种常见的接口通信方式,Axis2是Apache软件基金会提供的一个开源工具,专门用于构建和部署Web服务。它基于SOAP(简单对象访问协议)标准,支持WS-*规范,提供了高效且...
Apache Axis2是Java平台上一个高效且灵活的Web服务框架,它允许开发者用多种方式创建和消费Web服务。本篇将深入探讨使用Axis2实现Web服务的五种主要方法:POJO、AXIOM、ADB、XMLBeans和JIBX,并涵盖客户端和服务器端...
【Axis2 WebService 开发指南】是关于使用Apache Axis2框架创建和操作Web服务的教程。Axis2是Axis1的升级版,提供了更多的功能和改进的性能。在开始之前,你需要下载并安装必要的开发工具,包括Axis2的jar包和...
Web服务的核心技术之一就是WebService,而Axis2是Apache软件基金会提供的一个高效、可扩展且灵活的Web服务引擎,常用于构建和部署Web服务。MyEclipse是一款强大的集成开发环境(IDE),特别适合Java EE项目的开发,...
标题中的“axis2之webservice”指的是Apache Axis2框架下的Web服务实现技术。Apache Axis2是Axis1的升级版,是一个高效、灵活且强大的Web服务引擎,用于创建和部署Web服务。它支持SOAP 1.1和1.2,以及RESTful Web...
使用Axis2创建Web服务的第一步是编写服务接口和服务实现。接口定义了服务提供的操作,而实现则提供了具体的业务逻辑。例如,我们可以创建一个名为`HelloWorldService`的接口,其中包含一个`sayHello`方法,然后提供...
本话题将详细阐述如何使用Axis2创建Java Web服务以及客户端在调用这些服务时所需的重要依赖库。 1. **Axis2组件**: - `axis2-kernel-1.5.jar`:这是Axis2的核心库,包含了Web服务的基础架构和处理机制。 - `axis...
总的来说,AXIS2是一个强大的Web服务框架,它提供了丰富的功能和高度的灵活性,使得开发者能够高效地创建、部署和管理Web服务。无论你是初学者还是经验丰富的开发者,掌握AXIS2都能极大地提升你在Web服务领域的技能...
标题“axis2 + webService所需要的jar包”指的是为了在项目中使用Axis2框架来实现Web服务,你需要包含一系列特定的Java类库(jar包)。这些jar包提供了 Axis2 和Web服务相关的功能支持。描述中的“已经简化了不必要...
在Java开发中,Axis2是一个广泛使用的Web服务框架,它基于Apache SOAP项目,提供了一种高效、灵活且可扩展的方式来创建和部署Web服务。本文将详细介绍标题为“axis2访问WebService所需jar包”的相关知识点,以及描述...
本示例将深入探讨如何在Axis2环境中创建和部署一个简单的Web服务端点,以便于理解其核心概念和技术。 一、 Axis2 框架简介 Axis2是基于AXIOM(Abstract XML Information Model)和SOAP引擎Axiom的下一代Web服务引擎...
而Axis是Apache软件基金会开发的一个开源工具,它主要用于Java环境中创建和部署Web服务。本篇文章将详细探讨如何使用Axis来实现Web服务的发布服务,并提供客户端和服务端的操作指南。 **一、Axis简介** Axis是Java ...
《Axis2 WebService开发指南》是一本专注于Java平台上的Web服务框架Axis2的权威书籍,适合于希望深入了解和使用Axis2进行Web服务开发的IT专业人士。Axis2是Apache软件基金会开发的一个高性能、灵活且可扩展的Web服务...
WebService之Axis2实例是Web服务开发中的一个重要环节,它基于SOAP协议,允许不同平台和语言间的应用程序进行通信。本文将详细介绍Axis2实例的创建、配置和运行,以及如何利用Eclipse IDE、JDK 1.7和Tomcat 7.0进行...
3. **服务部署**:Axis2支持多种部署方式,如AAR(Axis Archive)文件、WAR(Web Application Archive)文件或者直接通过代码部署。AAR文件是包含服务接口、实现和服务配置的特殊ZIP文件。 4. **传输协议**:Axis2...
里面包含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包
在开发Web服务时,Axis2是一个非常流行的Java框架,它提供了高效且灵活的方式来创建和部署Web服务。本文将深入探讨Axis2的相关知识点,以及如何利用它与Spring框架进行整合。 一、Axis2简介 Axis2是Apache软件基金...