使用XFire组件开发WebService实例
1、WebService简介 WebService又是一种高级应用,与之前学习的Struts、Spring、Hibernate等框架不同。WebService是面向服务的架构(SOA)。那么它到底是做什么用的?什么才是面向服务的架构? 让我们来看一种需求,集团公司可能具有多种WEB应用。比如,前年开发了个进销存系统、去年开发了一个ERP、今年又开发了一个OA。现在这家集团公司需要将这三个系统整合,难道需要重新编码将它们整合吗?而这三个系统又是用不同语言编写的,这种成本对公司来说无疑是一种浪费。WebService可以很好的解决这种需求。 WebService是可以进行跨语言、跨平台、分布式系统间整合的方案,WebService像是一条线将这些系统穿起来——企业服务总线(ESB)。WebService使用简单对象访问协议(SOAP)使用http协议传输xml数据(xml是最常用的,也有其他格式数据。)来完成系带间的整合。 什么是整合?当然是功能和数据的整合,也就是一个系统可以调用另一个系统的WebService接口来完成数据的交互。这样我们就需要知道,提供WebService服务功能的应用公开了哪些接口,我们可以通过WebService描述文档(WSDL)得知。WSDL不需要我们手动编写,Java的WebService实现可以为我们自动生成。JDK1.6新增支持WebService,但还不够成熟。所以我们可以使用一些第三方开源组织提供的WebService组件。 2、Xfire组件 1.XFire简介 XFire 是与Axis 2并列的新一代Web Service框架,通过提供简单的API支持Web Service各项标准协议,帮助你方便快速地开发Web Service应用。 相对于Axis来说,目前XFire相对受欢迎,加上其提供了和Spring集成的支持,在目前的Web Service开源社区拥有众多的追随者。并且因为XFire为Spring提供的支持,使得我们可以很容易在Spring中使用XFire构建Web Service应用。 XFire 与Axis2相比具有如下特征:
XFire 与Axis1性能的比较如下:
XFire 在WebService框架中开始较晚,它从现有的框架中借鉴了许多优秀的理念,力争将Web Service的应用开发难度降到最低。此外,还提供了各种绑定技术、支持多种传输协议,对WebService体系中许多新的规范提供了支持。 2.XFire组件下载 XFire在2007年后已停止更新。正式更名为Apache CXF,亦可以说是XFire2.0。
XFire - XFire安装包:XFire框架目前最后的一个版本是1.2.6,在2007年5月3日发布,可以访问xfire.codehaus.org下载XFire框架的安装包。
解压缩后形成的文件目录结构如下:
3、MyEclipse使用XFire组件开发WebService实例 服务端(为客户端提供WebService接口)开发: 1.创建工程,导入XFire组件所需jar包到lib下:xfire-all-1.2.6.jar和lib目录所有jar包(根据实际需要确定)。 2.创建完成后,打开web.xml,XFire的配置如下: <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.5" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> servlet> servlet-name>XFireServlet</servlet-class>org.codehaus.xfire.transport.http.XFireConfigurableServletload-on-startup>0servlet-mappingurl-pattern>/services/*welcome-file-listwelcome-file>index.jsp> web-app> 3.创建Java Code和services.xml。 服务端接口和默认实现: public interface HelloWebService {
public String example(String message);
}
? class HelloWebServiceImpl implements String example(String message) {
return "这是服务端返回:" + message;
}
}
创建对应的services.xml配置文件,xfire默认的加载services.xml路径是classesMETA-INF。代码如下: beans ="http://xfire.codehaus.org/config/1.0"servicename>HelloWebServiceserviceClass>com.server.HelloWebServiceimplementationClass>com.server.HelloWebServiceImplbeans 至此,服务端代码生成完毕!工程结构如图:
部署并测试服务端:
开发客户端(调用服务端提供的WebService接口方法): 经过以上几步,我们已经成功发布了一个WebService,现在需要创建一个客户端来调用该服务
import java.net.URL;
org.codehaus.xfire.client.Client;
class HelloWSClient {
static void main(String[] args) throws Exception{
Client client = new Client(new URL("http://localhost:8080/WebServiceServer/services/HelloWebService?wsdl"));
Object[] result = client.invoke("example",new Object[]{"Hello World!"});
System.out.println(result[0]);
}
}
或将接口HelloWebService.java复制到工程中来,调用接口的方法。不止可以返回字符串,也可以是集合数组等。 java.util.List;
org.codehaus.xfire.client.XFireProxyFactory;
org.codehaus.xfire.service.Service;
org.codehaus.xfire.service.binding.ObjectServiceFactory;
org.codehaus.xfire.transport.http.CommonsHttpMessageSender;
Exception{
String serviceURL = "http://localhost:8080/WebServiceServer/services/HelloWebService";
Service serviceModel = new ObjectServiceFactory().create(HelloWebService.class,255); line-height:1.5!important">null,"http://localhost:8080/WebServiceServer/services/HelloWebService?wsdl",255); line-height:1.5!important">null);
XFireProxyFactory serviceFactory = new XFireProxyFactory();
HelloWebService service = (HelloWebService) serviceFactory.create(serviceModel,serviceURL);
Client client = Client.getInstance(service);
// disable timeout
client.setProperty(CommonsHttpMessageSender.HTTP_TIMEOUT,"0");
List<String> list = service.getList();
for (String string : list) {
System.out.println(string);
}
}
}
客户端工程结构如图:
运行客户端代码,输出:这是服务端返回:Hello World! 调用WebService成功! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |