在这一节,你将了解到如何将一个普通的java文件转换为一个web服务,services.xml文件是如何定义的,如何发布这个web服务、如何获得这个服务的WSDL、如何创建Client代码、如何测试这个web服务。
首先打开Eclipse,创建一个普通的java工程,将xfire所需的jar和xfire的jar加入到工程所需的类库引用中。创建一个简单的java文件,这个java文件简单到只提供一个add方法。
package com.kuaff.xfire.samples; public class MathService { public long add(int p1, int p2) { return p1 + p2; } } |
在src目录下创建META-INF/xfire目录,然后在META-INF/xfire目录下创建services.xml文件,文件内容为:
<beans xmlns="http://xfire.codehaus.org/config/1.0"> <service> <name>MathService</name> <namespace>http://www.kuaff.com/xfire/samples/MathService</namespace> <serviceClass>com.kuaff.xfire.samples.MathService</serviceClass> </service> </beans>
|
这个文档定义了你要发布的web服务,这个定义了一个名为MathService的服务,服务类为com.kuaff.xfire.samples.MathService。
这样我们的一个简单的web服务就开发完成了,下面就要把它发布出去。
将工程bin目录下的所有的文件复制到第一节中配置的tomcat/webapps/xfire/WEB-INF/classes文件夹下,启动tomcat,你就可以检查这个web服务是否发布成功了。
打开浏览器,在浏览器地址栏中输入http://localhost:8080/xfire/services/,正常情况下应该浏览器应该显示类似下图所示的页面。
<!--[if !vml]--><!--[endif]-->
<!--[if !vml]--><!--[endif]-->
注意:请在浏览器中输入http://localhost:8080/xfire/services/而不是http://localhost:8080/xfire/services,虽然两者显示的页面相同,但是点击页面上的链接,后者的链接会出错,因为后者后面少加了一个“/”。
点击[wsdl]链接,可以查看这个web服务的wsdl文档。
<!--[if !vml]--><!--[endif]-->
如果在你的机器上的显示如上面所示,则说明你的这个web服务发布成功,可以正常提供基于http的web服务。
下面一个问题就是如何开发一个Client,来消费(使用)这个web服务。
XFire、Axis、asp.net以及其它的一些商业产品都提供了根据wsdl文档创建客户端代码的工具。这里采用Xfire提供的wsgen工具来创建客户端的访问代码。
Wsgen是xfire提供的一个ant task,task的申明如下:
<taskdef name="wsgen" classname="org.codehaus.xfire.gen.WsGenTask" classpathref="xfire的jar路径" /> |
这样,就可以在build.xml文件中使用这个task:
<wsgen outputDirectory="client" wsdl="MathService.wsdl" package="com.kuaff.xfire.samples" /> |
outputDirectory属性定义创建的代码所在的文件夹,wsdl是web服务的wsdl文件,package代表创建的代码的packege。还可以通过binding属性制定bind类型:jaxb或者是xmlbeans,
这样,就会在client文件夹下创建多个java文件,这些文件提供了访问web服务的方法。
在这里声明一点,创建的代码大量的使用了java注释,这个JSE5中提供的新特性,所以你需要使用JSE5编译,Eclipse也必须要3.1以上的版本。
这段ant脚本将创建三个文件:MathServicePortType、MathServiceImpl和MathServiceClient。MathServicePortType是这个web服务的客户端接口存根、MathServiceImpl实现了这个接口。MathServiceClient封装了访问这个web服务的方法。
最后,你可以创建一个单元测试类,用来测试这个客户端类。这个类的内容如下:
package com.kuaff.xfire.samples; import junit.framework.TestCase; public class MathServiceClientTest extends TestCase { public void testAdd() { MathServiceClient client = new MathServiceClient(); MathServicePortType ms = client.getMathServiceHttpPort(); long result = ms.add(10, 20); assertEquals(result, 30); } } |