WebService – Axis2与Spring整合并发布多个service(同样使用services.xml)
本篇演示与spring整合下服务端的开发并发布两个service(客户端如何调用,参考上篇)。其实也就是把bean交给Spring容器来管理。
测试上除了你基于SOAP使用Client调用service,Axis2默认情况下还支持Restful风格。当然后者仅支持简单类型参数,二进制文件等不支持。
【1】环境配置
服务端继续沿用上一个项目,不过要添加spring包/axis2与spring整合jar并修改配置。
① 添加jar;
② 添加applicationContext.xml并配置如下:
只配了自动扫描,说明类使用了注解
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
③ 为接口实现类添加@Service注解
④ 修改web.xml 如下:
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> contextConfigLocation classpath:applicationContext.xml org.springframework.web.context.ContextLoaderListener Apache-Axis Servlet AxisServlet org.apache.axis2.transport.http.AxisServlet 1 AxisServlet /services/* index.jsp index.html
⑤ 修改services.xml
路径如下:
配置如下:
AxisSpringService <!-- SpringBeanName作用类似于普通配置中的ServiceClass,都是用来创建服务类对象,只不过普通配置使用反射来创建 。 加入Spring之后,对象的创建交给了Spring的IOC容器,SpringBeanName指定要发布成WebService的Java类,SpringBeanName参数是JavaBean的名称。 SpringBeanName固定的不能改 ,因为springWebService是spring中注册的实现类得id。 如果不使用spring,可以使用ServiceClass属性,ServiceClass参数要指定要发布成WebService的Java类,并指定全类名的方式。 --> myServiceImpl org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier <!-- 在这里最值得注意的是元素,该元素用于设置处理WebService方法的处理器。 例如,getAge方法有一个返回值,因此,需要使用可处理输入输出的RPCMessageReceiver类, 而update方法没有返回值,因此,需要使用只能处理输入的RPCInOnlyMessageReceiver类。 -->
【2】部署到Tomcat,运行
获取的wsdl地址:
http://localhost:8080/Axis2/services/AxisSpringService?wsdl
即,schema+IP+port+contextPath+services+serviceName+?wsdl
targetNamespace如下:
http://impl.service.Axis2.web.com
如果要为option设置action,则示例如下:
Options options = new Options(); // 指定调用WebService的URL EndpointReference targetEPR = new EndpointReference(url); options.setAction("http://impl.service.Axis2.web.com/sayHello");
浏览器出现如下图说明正常:
使用上一篇中的客户端进行测试(url变了)
客户端输出结果如下:
使用Restful风格进行测试:
浏览器输入地址:
http://localhost:8080/Axis2/services/ AxisSpringService2/sayHello?name=tom
结果如下图:
服务端输出结果如下:
【3】配置并发布两个service
上面演示的一个service下axis2与spring整合。如果两个service呢?下面进行演示。
① 拷贝MyServiceImpl并重命名为MyServiceImpl2
一个接口,两个实现类,发布成两个不同的service。
修改其方法如下:
package com.web.Axis2.service.impl; import org.springframework.stereotype.Service; import com.web.Axis2.service.MyService; @Service public class MyServiceImpl2 implements MyService{ @Override public String sayHello(String name) { //service2 用于区分是第二个service的方法被调用 System.out.println("this is service2 "+name); return "hello "+name; } }
② 修改services.xml
AxisSpringService myServiceImpl org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier AxisSpringService2 myServiceImpl2 org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier
如上面配置所示,使用了serviceGroup元素。一个xml中只能有一个serviceGroup元素。每个serviceGroup元素下可以有多个service元素,每一个service元素表示一个WebService。
③ 使用不同的url进行测试
http://localhost:8080/Axis2/services/AxisSpringService?wsdl http://localhost:8080/Axis2/services/AxisSpringService2?wsdl
其实就是service名字改变了。
查看第一个wsdl文件:
AxisSpringService
这里需要额外说明,Axis2默认同时支持SOAP1.1、SOAP1.2和HTTP协议。即厂家的SOAP和REST调用方式。如下图所示:
进行测试,服务端输出结果如下:
表示两个service被正常调用!!!
发表评论