微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Axis2创建WebService实例

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

Old Java Object,中文可以翻译成:普通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文件中不能出现中文,不然出现Faulty Services错误!!要想在services.xml中加中文

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

4:  %AXIS2_HOME%\bin\wsdl2java -uri http://localhost:8080/axis2/services/HelloService?wsdl -p client -s -o stub

 

  一、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实现Web Service,虽然可以将POJO类放在axis2\WEB-INF\pojo目录中直接发布成Web Service,
  这样做不需要进行任何配置,但这些POJO类不能在任何包中。这似乎有些不方便.
  为此,Axis2也允许将带包的POJO类发布成Web Service。先实现一个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类发布成Web Service,需要一个services.xml文件
   这个文件需要放在meta-inf目录中,该文件内容如下:

Xml代码

复制代码

 

收藏代码

Axis2创建WebService实例

版权声明:本文为博主原创文章,未经博主允许不得转载。

猜你在找
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐