Axis2 POJO实现WebService(一)发布
一、Axis2的下载和安装
读者可以从如下的网址下载Axis2的最新版本:
下载: axis2-1.6.2-bin;
二、编写和发布WebService
1)新建一个POJO:
1 /** 2 * @author damon.huang 3 * 4 */ 5 public class SimpleService 6 { 7 public String getGreeting(String name) 8 { 9 return "Hello: " + name; 10 } 11 public int getPrice() 12 { 13 return new java.util.Random().nextInt(1000); 14 } 15 16 17 }
在SimpleService类中有两个方法,由于这两个方法都是public方法,因此,它们都将作为WebService方法被发布。
编译SimpleService类后,将SimpleService.class文件放到tomcat\webapps\axis2\WEB-INF\pojo目录中(如果没有pojo目录,则建立该目录)。现在我们已经成功将SimpleService类发布成了WebService。在浏览器地址栏中输入如下的URL:(无须重启tomcat)
http://localhost:8080/axis2/services/listServices
这时当前页面将显示所有在Axis2中发布的WebService,如图所示。
三、网页调用测试
在浏览器地址栏中输入如下的两个URL来分别测试getGreeting和getPrice方法:
http://localhost:8080/axis2/services/SimpleService/getGreeting?args0=bill(注意:这里的args0是根据(点击SimpleService)http://localhost:8080/axis2/services/SimpleService?wsdl自动生成的节点参数)
http://localhost:8080/axis2/services/SimpleService/getPrice
图1和图2分别显示了getGreeting和getPrice方法的测试结果。
图1
图2
在编写、发布和测试0配置的WebService时应注意如下几点:
1. POJO类不能使用package关键字声明包。
2. Axis2在默认情况下可以热发布WebService,也就是说,将WebService的.class文件复制到pojo目录中时,Tomcat不需要重新启动就可以自动发布WebService。如果想取消Axis2的热发布功能,可以打开tomcat\webapps\axis2\WEB-INF\conf\axis2.xml,找到如下的配置代码:
将true改为false即可。要注意的是,Axis2在默认情况下虽然是热发布,但并不是热更新,也就是说,一旦成功发布了WebService,再想更新该WebService,就必须重启Tomcat。这对于开发人员调试WebService非常不方便,因此,在开发WebService时,可以将Axis2设为热更新。在axis2.xml文件中找到<parameter name="hotupdate">false</parameter>,将false改为true即可。
3. 在浏览器中测试WebService时,如果WebService方法有参数,需要使用URL的请求参数来指定该WebService方法参数的值,请求参数名与方法参数名要一致,例如,要测试getGreeting方法,请求参数名应为name,如上面的URL所示。
4. 发布WebService的pojo目录只是默认的,如果读者想在其他的目录发布WebService,可以打开axis2.xml文件,并在<axisconfig>元素中添加如下的子元素:
上面的配置允许在tomcat\webapps\axis2\WEB-INF\my目录中发布WebService。例如,将本例中的SimpleService.class复制到my目录中也可以成功发布(但要删除pojo目录中的SimpleService.class,否则WebService会重名)