Axis2创建WebService实例

来源:互联网 发布:mac进入屏保快捷键 编辑:程序博客网 时间:2024/05/17 07:54

POJO和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain OrdinaryJava Object / Plain

Old JavaObject,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,

但是JavaBean则比POJO复杂很多,JavaBean是一种组件技术,根据我的理解就好像你做了一个扳子,这个板子

有头head和柄handle,而这个扳子会在很多地方被拿去用,这个扳子提供了多种功能(你可以拿这个扳子扳

turn()、锤hammer()、撬prize()等等),而这个扳子就是一个组件。
很显然POJO也是JavaBean的一种,但是它不提供扳turn()、锤hammer()、撬prize()等功能,只有简单的设置

头setHead()/getHead()和柄setHandle()/getHandle()的方法,这样我们只能称它为POJO。一般在web应用程

序中建立一个数据库的映射对象时用到。

1:POJO类不能使用package关键字声明包,改掉后必须重启tomcat(因为我i之前错误的发布了一次,能热发布但

是不能热更新(就是说一旦成功发布再更新就需要重启))

2:访问http://localhost:8080/axis2/services/HelloService/sayHello  (HelloService的sayHello方法)
 
http://localhost:8080/axis2/services/HelloService/sayHelloToPerson?name=bill 传参
http://ws.apache.org/axis2">
  hello
 

3:jar cvf ws.aar.       aar文件实际上就是改变了扩展名的.jar文件
 jar命令(c 创建新文件,v显示过程,f指定归档文件名)
 jar cvf lm.jar Lm.class Lm.java要么在后面指定所要打包的文件,打包后的文件名为lm.jar
 C:\ws>jar cvf ws.aar .直接将ws文件夹下的文件都打包成ws.aar文件(注意空格加.)
注意:在servers.xml文件中不能出现中文,不然出现FaultyServices错误!!要想在services.xml中加中文

,需要将编码设为UTF-8或GBK,我是这样设置的,但是不知道为何出现错误!!

4:  %AXIS2_HOME%\bin\wsdl2java-uri http://localhost:8080/axis2/services/HelloService?wsdl-pclient -s -ostub

 

WebServiceTomcatApacheWebXML 

  一、Axis2的下载和安装


    1.可从http://ws.apache.org/axis2/下载Axis2的最新版本:
     可以下载如下两个zip包:
     axis2-1.5.4-bin.zip
     axis2-1.5.4-war.zip
     其中 axis2-1.5.4-bin.zip文件中包含了Axis2中所有的jar文件,
     axis2-1.5.4-war.zip文件用于将WebService发布到Web容器中。


    2.将axis2-1.5.4-war.zip文件解压到相应的目录,将目录中的axis2.war文件放到\webapps目录中,
    并启动Tomcat,在浏览器地址栏中输入如下的URL:
    http://localhost:8080/axis2/,如看到axis2的主页面则安装成功。

 

  二、编写和发布WebService


  (1)用POJO形式发布(无需配置)


    在Axis2中不需要进行任何的配置,就可以直接将一个简单的POJO发布成WebService。
   其中POJO中所有的public方法将被发布成WebService方法。
    示例代码如下:

    

Java代码 复制代码 收藏代码Axis2创建WebService实例
  1. public class HelloService   
  2.     public String sayHello(){  
  3.         return "hello" 
  4.         
  5.     public String sayHelloToPerson(String name){          
  6.         if(name==null){  
  7.             name "nobody" 
  8.          
  9.         return "hello,"+name;  
  10.      
  11.  
public class HelloService {         public String sayHello(){                return "hello";        }               public String sayHelloToPerson(String name){                            if(name==null){                        name = "nobody";                }                return "hello,"+name;        }}

   编译HelloService类后,将HelloService.class文件放到\webapps\axis2\WEB-INF\pojo目录中
  (如果没有pojo目录,则建立该目录)。现在我们已经成功将HelloService类发布成了WebService。
  在浏览器地址栏中输入如下的URL:
    http://localhost:8080/axis2/services/listServices


  在浏览器地址栏中输入如下的两个URL来分别测试sayHelloToPerson和sayHello方法:
   1.http://localhost:8080/axis2/services/HelloService/sayHello
   2.http://localhost:8080/axis2/services/HelloService/sayHelloToPerson?name=bill


  页面显示如下结果:

Xml代码 复制代码 收藏代码Axis2创建WebService实例
  1. <</SPAN>ns:sayHelloToPersonResponse xmlns:ns="http://ws.apache.org/axis2">  
  2.     <</SPAN>return>hello,bill</</SPAN>return>   
  3. </</SPAN>ns:sayHelloToPersonResponse>  
         hello,bill  

 

  在编写、发布和测试WebService时应注意如下几点:
    1. POJO类不能使用package关键字声明包。


    2.Axis2在默认情况下可以热发布WebService,也就是说,将WebService的.class文件复制到pojo目录中时,
       Tomcat不需要重新启动就可以自动发布WebService。
       如果想取消Axis2的热发布功能,可以打开\webapps\axis2\WEB-INF\conf\axis2.xml,
       找到如下的配置代码:

Xml代码 复制代码 收藏代码Axis2创建WebService实例
  1. <</SPAN>parameter name="hotdeployment">true</</SPAN>parameter>  
true

 

 将true改为false即可。要注意的是,Axis2在默认情况下虽然是热发布,但并不是热更新.
  也就是说,一旦成功发布了WebService,再想更新该WebService,就必须重启Tomcat。
  这对于开发人员调试WebService非常不方便,因此,在开发WebService时,可以将Axis2设为热更新。
  在axis2.xml文件中找到

Xml代码 复制代码 收藏代码Axis2创建WebService实例
  1. <</SPAN>parameter name="hotupdate">false</</SPAN>parameter>  
false

 

   将false改为true即可。


    3.在浏览器中测试WebService时,如果WebService方法有参数,需要使用URL的请求参数来指定该WebService方法
    参数的值,请求参数名与方法参数名要一致,例如,要测试sayHelloToPerson方法,请求参数名应为name,如上面的URL所示。


    4. 发布WebService的pojo目录只是默认的,如果读者想在其他的目录发布WebService,
    可以打开axis2.xml文件,并在元素中添加如下的子元素:

Xml代码 复制代码 收藏代码Axis2创建WebService实例
  1. <</SPAN>deployer extension=".class" directory="my" class="org.apache.axis2.deployment.POJODeployer"/>  
 

 

  上面的配置允许在\webapps\axis2\WEB-INF\my目录中发布WebService。
  例如,将本例中的HelloService.class复制到my目录中也可以成功发布
  (但要删除pojo目录中的SimpleService.class,否则WebService会重名)。

 

(2)使用services.xml配置文件发布


  用Axis2实现WebService,虽然可以将POJO类放在axis2\WEB-INF\pojo目录中直接发布成Web Service,
  这样做不需要进行任何配置,但这些POJO类不能在任何包中。这似乎有些不方便.
  为此,Axis2也允许将带包的POJO类发布成WebService。先实现一个POJO类,代码如下:

Java代码 复制代码 收藏代码Axis2创建WebService实例
  1. package com.sinosoft.webservice;  
  2. public class HelloServiceNew            
  3.     public String sayHelloNew(){  
  4.         return "hello" 
  5.                 
  6.     public String sayHelloToPersonNew(String name){       
  7.         if(name==null){  
  8.             name "nobody" 
  9.                     
  10.         return "hello,"+name;  
  11.      
  12.     public void updateData(String data){  
  13.         System.out.println(data+已更新。");  
  14.      
  15.  
package com.sinosoft.webservice;public class HelloServiceNew {                          public String sayHelloNew(){                return "hello";        }                               public String sayHelloToPersonNew(String name){                         if(name==null){                        name = "nobody";                }                                       return "hello,"+name;        }        public void updateData(String data){                System.out.println(data+" 已更新。");        }}

 

   要想将HelloServiceNew类发布成WebService,需要一个services.xml文件,
  这个文件需要放在META-INF目录中,该文件的内容如下:

Xml代码 复制代码 收藏代码Axis2创建WebService实例
原创粉丝点击