accp的课程的webService的框架是xfire。
以下是Ibm dw中对Xfire的理论介绍。
---------------------------
XFire 是 codeHaus 组织提供的一个开源框架,它构建了 POJO 和 SOA 之间的桥梁,主要特性就是支持将 POJO 通过非常简单的方式发布成 Web 服务,这种处理方式不仅充分发挥了 POJO 的作用,简化了 Java 应用转化为 Web 服务的步骤和过程,也直接降低了 SOA 的实现难度,为企业转向 SOA 架构提供了一种简单可行的方式。
XFire 目前的稳定版本是 1.2.6,(在myEclipse6.01中集成了Xfire1.2.6.)
目前支持的特性主要包括:支持将 Web 服务绑定到 POJO、XMLBeans、JAXB1.1、JAXB2.0 和 Castor;
- 支持基于 HTTP、JMS、XMPP 等多种协议访问 Web 服务;
- 支持多种 Web 服务业界重要标准如 SOAP、WSDL、Web 服务寻址(WS-Addressing)、Web 服务安全(WS-Security)等;
- 支持 JSR181,可以通过 JDK5 配置 Web 服务;
- 高性能的 SOAP 实现;
- 服务器端、客户端代码辅助生成;
- 对 Spring、Pico、Plexus 等项目的支持等。
-------------------------------------------------------------------------------
XFire 框架目前的最新版本是 1.2.6,可以访问 xfire.codehaus.org 下载 XFire 框架的安装包,下载时请选择“全部二进制发布包(Binary Distribution in zip package)”,而不仅仅是“XFire jar 文件(Jar of all XFire modules)”。
下载完成后,我们可以将下载的 .zip 文件解压缩到任意的文件夹中(后面的章节中使用 % XFIRE_HOME % 表示 XFire 框架的安装目录),解压缩后形成的文件目录结构如下:
-
api(目录)
api 目录中是 XFire 框架中所有类(class)对应的 API 文档,为开发者使用 XFire 完成应用开发提供帮助。
-
examples(目录)
examples 目录中包含了所有随 XFire 二进制包发布的实例,包括这些实例的源代码和相关 Web 应用配置内容。
-
lib(目录)
lib 目录中包含 XFire 运行所需要的外部支持类包(.jar文件),可以根据不同项目所需的 XFire 特性选择所需要的支持类包。保守的方法是在 Web 项目中包含所有的外部支持类包(.jar文件)。
-
manual(目录)
manual 目录中包含有 XFire 框架的帮助文档,开发者可以从这些帮助文档中学习更多运用 XFire 框架实现 SOA 的知识和技巧。
-
modules(目录)
modules 目录中包含了 XFire 框架根据不同特性分别编译的二进制包文件。发布基于 XFire 框架的 Web 项目时,可以选择使用该目录下的所有 .jar 文件,也可以选择 XFire-all-1.2.6.jar 文件。
-
XFire-all-1.2.6.jar
XFire 框架的二进制包文件,包含了全部的模块(modules)。
-
LICENSE.txt
LICENSE.txt 文件中包含了 XFire 框架的授权协议。
- NOTICE.txt
-
README.txt
这两个文件中包含了 XFire 发布时的一些有用的信息。
---------------------------------------
下面我们使用IDE开发一个简单的webServices.
一)使用MyEclipse6.01来开发一个webService服务端。
使用MyEclipse来开发webService的服务器端比较简单。主要经过如果几个步骤
1)首先建立一个WebServices工程
如果
其中myEclipse会自动配置好XFire的Servlet。
以下为Web.xml文件的配置内容
<servlet>
<servlet-name>XFireServlet</servlet-name>
<servlet-class>org.codehaus.xfire.transport.http.XFireConfigurableServlet</servlet-class>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>XFireServlet</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
2)定义WebService的接口
3)定义接口的实现类
4)创建 XFire 框架的服务发布文件 services.xml
按Xfire的开发指南上说是要在
WEB-INF/classes/META-INF/xfire/services.xml
的位置。但是MyEclipse已经在工程的下面建立了一个WebService/services.xml的文件。
其实是myclipse帮助我们映射好了位置而已。
其中各元素的功能如下:
-
service
service 标签和它所包含的 xml 内容为发布成 Web 服务的 POJO 提供完整的描述。
-
name
Web 服务被发布时所采用的唯一名称。
-
namespace
Web 服务发布时所使用的命名空间。
-
serviceClass
Web 服务接口类的全名,包括包名和类名。
-
implemetationClass
Web 服务实现类的全名,包括包名和类名。
下面我们就可以部署这个工程,顺便提一下,如果正常的话你可以在tomcat启动的过程中
看到如下的信息信息:
2010-6-18 14:38:26
org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
........
Exposing service with name {www.pengzj.com.cn/hellows}hellows
就可以知道xfire使用了spring。
现在我们可以在ie中输入如下的地址访问它
http://127.0.0.1:8080/xfire_hello_service/services/
会出现如下的可用服务列表:
点击wsdl的超链接出现这个wsdl文件的内容大致如下:
ok.这就表示服务端大功告成了。
接下来就是在客户端要如何调用WebServices了。