`

axis2操作webservice

阅读更多
最近要与别的公司做接口,用到了axis2,所以就在网上找些资料了解下,自己做了个小例子,发布与调用webservice

1.下载axis2
地址:http://axis.apache.org/axis2/java/core/download.cgi
下载Binary Distribution,axis2-1.6.2-bin.zip中包含了axis2所有jar,把jar包加入项目中

2.创建需要发布的服务
package com.dm.service;

public class HelloWorld {
	
	public String sayHello(String name) {
		return "Hello, " + name + ".";
	}

	public String saySorry(String name) {
		return "sorry, " + name + ".";
	}

	public String getWorld() {
		return "Hello, world!";
	}
}


3.编写web.xml及services.xml
将下载的axis2-1.6.2-bin.zip中webapp/web-inf/web.xml复制到项目中,去掉不需要的配置
<?xml version="1.0" encoding="utf-8"?>

<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">

<web-app>
    <display-name>Apache-Axis2</display-name>
    <servlet>
        <servlet-name>AxisServlet</servlet-name>
        <display-name>Apache-Axis Servlet</display-name>
        <servlet-class>org.apache.axis2.transport.http.AxisServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet>
        <servlet-name>AxisAdminServlet</servlet-name>
        <display-name>Apache-Axis AxisAdmin Servlet (Web Admin)</display-name>
        <servlet-class>
            org.apache.axis2.webapp.AxisAdminServlet</servlet-class>
    </servlet>  
    <servlet-mapping>
        <servlet-name>AxisServlet</servlet-name>
        <url-pattern>/servlet/AxisServlet</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>AxisServlet</servlet-name>
        <url-pattern>*.jws</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>AxisServlet</servlet-name>
        <url-pattern>/services/*</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>AxisAdminServlet</servlet-name>
        <url-pattern>/axis2-admin/*</url-pattern>
    </servlet-mapping>

    <mime-mapping>
        <extension>inc</extension>
        <mime-type>text/plain</mime-type>
    </mime-mapping>

   <welcome-file-list>
      <welcome-file>index.jsp</welcome-file>
      <welcome-file>index.html</welcome-file>
      <welcome-file>/axis2-web/index.jsp</welcome-file>
    </welcome-file-list>

</web-app>



services.xml
如果只发布单个服务,则用<service></service>
如果发布多个服务,则用<serviceGroup><service></service></serviceGroup>
<serviceGroup>
	<service name="HelloWorld">
		<description>
			HelloWorld Service Example
		</description>
		<parameter name="ServiceClass">
			com.dm.service.HelloWorld
		</parameter>
		<!-- 当不指定operation时必须加上这个
		<messageReceivers>
			<messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-only" class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
			<messageReceiver  mep="http://www.w3.org/2004/08/wsdl/in-out"  class="org.apache.axis2.rpc.receivers.RPCMessageReceiver"/>
		</messageReceivers> -->
		<operation name="sayHello">
			<messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
		</operation>
		<operation name="saySorry">
			<messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
			<!-- 有返回值 -->
		</operation>
		<operation name="getWorld">
			<messageReceiver
				class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
				<!-- 无返回值 -->
		</operation>
	</service>
	
	<!-- <service name="weather">
		<description>
			getWeather
		</description>
		<parameter name="ServiceClass">
			com.dm.service.impl.WeatherImpl
		</parameter>
		<messageReceivers>
			<messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-only" class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
			<messageReceiver  mep="http://www.w3.org/2004/08/wsdl/in-out"  class="org.apache.axis2.rpc.receivers.RPCMessageReceiver"/>
		</messageReceivers>
		<operation name="getWeather">
			<messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
		</operation>
	</service> -->
</serviceGroup>

这里要注意下services.xml的放置位置



4.运行发布服务
测试地址:http://127.0.0.1:8080/axisforWebService/services/HelloWorld?wsdl
打开如下图则说明发布成功了

好了,服务现在已经发布了,下面我们来调用这个服务

5.调用服务
方式一:
package common;

import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.Constants;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;

public class TestWebservice {
	private static EndpointReference targetEPR = new EndpointReference(
			"http://localhost:8080/axisforWebService/services/HelloWorld");

	public static OMElement sayHello(String symbol) {
		OMFactory fac = OMAbstractFactory.getOMFactory();
		OMNamespace omNs = fac
				.createOMNamespace("http://service.dm.com", "tns");
		OMElement method = fac.createOMElement("saySorry", omNs);
		OMElement value = fac.createOMElement("name", omNs);
		value.addChild(fac.createOMText(value, symbol));
		method.addChild(value);
		return method;
	}

	public static void main(String[] args) {
		try {
			OMElement getPassenger = sayHello("heiwado");
			Options options = new Options();
			options.setTo(targetEPR);
			options.setTransportInProtocol(Constants.TRANSPORT_HTTP);
			ServiceClient sender = new ServiceClient();
			sender.setOptions(options);
			OMElement result = sender.sendReceive(getPassenger);
			String response = result.getFirstElement().getText();
			System.err.println("Current passengers: " + result);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}


运行结果:Current passengers: <ns:saySorryResponse xmlns:ns="http://service.dm.com"><ns:return>sorry, heiwado.</ns:return></ns:saySorryResponse>

方式二:
package common;

import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.AxisFault;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;

public class WebserviceUtils {
	public static void main(String[] args) {
		try {
			ServiceClient sc = new ServiceClient();
			Options opts = new Options();
			opts.setTo(new EndpointReference(
					"http://localhost:8080/axisforWebService/services/HelloWorld"));
			opts.setAction("urn:echo");
			opts.setTimeOutInMilliSeconds(10000);
			sc.setOptions(opts);
			OMElement res = sc.sendReceive(createPayLoad());
			System.out.println(res);
		} catch (AxisFault e) {
			e.printStackTrace();
		}
	}

	public static OMElement createPayLoad() {
		OMFactory fac = OMAbstractFactory.getOMFactory();
		OMNamespace omNs = fac.createOMNamespace(
				"http://service.dm.com", "HelloWorld");
		OMElement method = fac.createOMElement("sayHello", omNs);
		OMElement value = fac.createOMElement("name", omNs);
		value.setText("hehaisu");
		method.addChild(value);
		return method;
	}
}


方式三:
package common;

import javax.xml.namespace.QName;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;

public class WebserviceUtils4 {
	public static void main(String[] args) {
		String url = "http://localhost:8080/axisforWebService/services/HelloWorld";
		String result = null;
		try {
			// 使用RPC方式调用WebService
			RPCServiceClient serviceClient = new RPCServiceClient();
			Options options = serviceClient.getOptions();
			// 指定调用WebService的URL
			EndpointReference targetEPR = new EndpointReference(url);
			options.setTo(targetEPR);
			// 在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名,也就是<wsdl:definitions>元素的targetNamespace属性值
			// // 指定要调用的getWorld方法及WSDL文件的命名空间.....
			QName opAddEntry = new QName("http://service.dm.com", "saySorry");
			//
			// 指定getGreeting方法的参数值,如果有多个,继续往后面增加即可,不用指定参数的名称
			Object[] opAddEntryArgs = new Object[] { "上海" };
			// 返回参数类型,这个和axis1有点区别
			// invokeBlocking方法有三个参数,其中第一个参数的类型是QName对象,表示要调用的方法名;
			// 第二个参数表示要调用的WebService方法的参数值,参数类型为Object[];
			// 第三个参数表示WebService方法的返回值类型的Class对象,参数类型为Class[]。
			// 当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{}
			// 如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,
			// 该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同
			// 指定getGreeting方法返回值的数据类型的Class对象.....
			Class[] classes = new Class[] { String.class };
			// 调用getGreeting方法并输出该方法的返回值.......
			result = (String)serviceClient.invokeBlocking(opAddEntry,
					opAddEntryArgs, classes)[0];
			//调用无返回值的方法则用serviceClient.invokeRobust方法		
			//serviceClient.invokeRobust(opAddEntry, opAddEntryArgs);
			System.out.println(result);
			
			
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

好了,服务调用就先说到这了,下次再去弄下cxf
技术交流群:312740759
  • 大小: 7.6 KB
  • 大小: 67.7 KB
分享到:
评论

相关推荐

    axis2发布webservice和调用axis2服务接口

    1. **创建WebService**:在Axis2中,可以通过编写一个简单的Java类并暴露其方法作为Web服务接口。这个类通常会遵循SOAP协议,定义服务操作。例如,你可以创建一个名为`HelloWorldService`的类,包含一个`sayHello`...

    axis2例子 webservice axis2 示例

    axis2例子 webservice axis2 示例axis2例子 webservice axis2 示例axis2例子 webservice axis2 示例axis2例子 webservice axis2 示例axis2例子 webservice axis2 示例

    Spring集成axis2实现webservice所用到的包

    2. **创建WebService**:在Spring中,可以通过定义一个实现了特定接口的类来创建Web服务。这个接口通常对应于服务的WSDL契约,而实现类则包含了实际的服务逻辑。 Axis2提供了`ServiceStub`类,可以帮助我们与服务...

    axis2实现webservice

    ### Axis2实现WebService知识点 #### 一、Axis2简介 - **定义**:Apache Axis2是基于Java的一个开源的WebService框架,它支持多种标准(包括SOAP1.1、SOAP1.2、WS-Addressing等),并且具有轻量级、模块化的特点。...

    Axis2创建WebService

    Axis2创建WebService

    axis2+spring webservice

    标题中的“axis2+spring webservice”指的是使用Apache Axis2框架与Spring框架集成来开发Web服务。Apache Axis2是Java环境中广泛使用的Web服务引擎,它提供了高性能、灵活且可扩展的架构。Spring框架则是一个全面的...

    基于axis2实现的webservice简单实现(客户端+服务端)。

    【标题】中的“基于axis2实现的webservice简单实现(客户端+服务端)”表明了本文将探讨如何使用Apache Axis2框架来创建和消费Web服务。Apache Axis2是Apache软件基金会开发的一个Web服务引擎,它提供了高效且灵活的...

    Java-tomcat-axis2开发webservice返回json数据

    标题“Java-tomcat-axis2开发webservice返回json数据”涉及的是使用Java、Tomcat服务器以及Axis2框架来创建Web服务,并返回JSON格式的数据。这是一个常见的技术组合,用于构建RESTful API或者提供服务化接口。下面...

    axis2webservice接口例子

    标题中的“axis2webservice接口例子”指的是使用Apache Axis2框架创建的一个Web服务接口实例。Apache Axis2是Java平台上的一款强大的Web服务开发工具,它提供了高效、灵活且可扩展的环境来构建和部署Web服务。这个...

    Axis2搭建WebService服务端demo

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

    Axis2开发webservice总结

    Axis2开发webservice总结,资源一般,希望对大家有用

    Axis2发布Webservice教程+工具(改良版)

    axis2-1.4.1-war.zip axis2-eclipse-codegen-wizard-1.4.zip axis2-eclipse-service-archiver-wizard-1.4.zip axis2创建webservice.txt(教程链接)

    axis2开发webservice(二)

    资源包含了:axis2-1.7.4-bin.zip、axis2-1.7.4-war.zip、axis2-eclipse-...备注:资源超过了70M 分成了3部分 见axis2方式开发webservice(一)和 axis2方式开发webservice(二)、 axis2方式开发webservice(三)

    Axis2(WebService)经典教程

    ### Axis2(WebService)经典教程知识点详述 #### 一、Axis2简介及特性 - **Axis2**作为Apache组织下的一个开源项目,是当前较为流行的WebService引擎之一。 - **特性**:支持SOAP 1.1和SOAP 1.2标准;支持RESTful...

    Axis2 创建 webservice 操作手册

    **Axis2创建Web服务操作手册** 在IT行业中,Web服务是一种常见的软件接口,它允许不同系统之间通过网络进行通信和数据交换。Apache Axis2是Java平台上一个强大的Web服务框架,用于构建和部署Web服务。本手册将深入...

    基于axis2的webservice

    【基于Axis2的Web服务详解】 在信息技术领域,Web服务是一种通过互联网进行通信的软件系统。它们使用标准的协议和格式,如XML(eXtensible Markup Language)和SOAP(Simple Object Access Protocol),使得不同...

    axis2调用webservice接口jar包

    本文将详细介绍如何使用Axis2调用WebService接口,并基于提供的jar包"axis2-1.7.6"进行说明。 **一、Axis2简介** Axis2是Apache软件基金会开发的一个Web服务引擎,它基于SOAP(Simple Object Access Protocol)和WS...

    axis2开发webservice

    总之,"Axis2 开发 WebService" 主要涉及使用 Apache Axis2 框架和 Eclipse IDE 创建、测试和部署基于 SOAP 的 WebServices,通过这一过程,开发者可以实现不同系统间的互操作性,推动企业级应用集成和数据共享。

    axis2_WebService_开发指南

    在某些情况下,可能会需要使用控制台命令(如Dos命令)来发布WebService,Axis2同样支持这种操作。对于需要跨多个WebService进行会话管理的情况,Axis2也提供了相应的解决方案。此外,对于需要异步调用WebService的...

    axis2客户端调用webService接口,精简jar包

    本文将深入探讨如何使用Axis2客户端调用WebService接口,并且会特别关注如何精简所需的jar包。 首先,了解Axis2客户端的基本概念是至关重要的。Axis2客户端是用于与远程Web服务交互的工具,它允许开发者通过SOAP...

Global site tag (gtag.js) - Google Analytics