原帖出处:http://zhangjunhd.blog.51cto.com/113473/23692

本文将介绍如何使用Tomcat5.0 Apache Axis2 开发、部署及测试一个简单的Web Service 应用。
1 工作环境
Eclipse 3.1.2+Lomboz+jdk1.5+ apache-tomcat-5.0.18+AXIS2:1.0(war 版本和bin 版本)
[url]http://ws.apache.org/axis2/download/1_0/download.cgi[/url] 页面 下载AXIS2 Binary Distribution url: [url]http://apache.justdn.org/ws/axis2/1_0/axis2-std-1.0-bin.zip[/url] war Distribution url: [url]http://apache.justdn.org/ws/axis2/1_0/axis2-1.0-docs.zip[/url] 。把这两个文件解压,比如解压缩的后得目录为C:"axis2-std-1.0-bin C:"axis2.war
Eclipse 下通过菜单window—preferences…--Java—Build Path—User Libraries 新建一个user library, 比如名字就叫axis2 C:"axis2-std-1.0-bin"lib 下的所有jar 文件包含进来。把axis2.war 拷贝到%TOMCAT-HOME%/webapps 下面。
 
2 .检验安装
Eclipse 下启动Tomcat ,在地址栏内输入[url]http://localhost:8080/axis2/[/url]
基于Tomcat5.0和Axis2开发Web Service应用实例_第1张图片
点击Validate ,将到达 Axis2 Happiness Page
基于Tomcat5.0和Axis2开发Web Service应用实例_第2张图片
3 WebService 中的HelloWorld
1 )新建一个动态web 工程,取名ZZaxis ,右键点击项目名,选择Properties-Java Build Path-Add Library-User Library-axis2
 
2 )新建package sample ,建立HelloWorld.java ,代码如下。
HelloWorld.java
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
 
public class HelloWorld {
       public OMElement sayHello(OMElement in){
              String name=in.getText();
              String info=name+"HelloWorld!";
              OMFactory fac=OMAbstractFactory.getOMFactory();
              OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
              OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
              resp.setText(info);
              return resp;
       }
}
 
3 )在WebContent"META-INF" 建立services.xml ,代码如下。
services.xml
<?xml version="1.0" encoding="UTF-8"?>
<service name="HelloWorld">
<description>
 This is a sample Web Service.
</description>
<parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
<operation name="sayHello">
 <messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
</operation>
</service>
 
4 )将目录sample 和目录META-INF 组织如下(新建目录example )。
+-example
|-------- +-sample
    |------- HelloWorld.class
|---------+-META-INF
       |-------services.xml
 
5 )打包生成aar 文件。
在命令符环境下,将当前目录转到example
jar cvf HelloWorld.aar . // 注意最后一个点,在当前目录下生成HelloWorld.aar
 
6 )在Eclipse 中启动Tomcat ,在地址栏下键入[url]http://localhost:8080/axis2/[/url] 。选择Administration ,输入用户名admin ,密码axis2 。选择左侧工具栏Tools- Upload Service ,上传之前打包的HelloWorld.aar 。该文件将在<CATALINA_HOME>/webapps/axis2"WEB-INF"services 目录下。
 
7 )编写客户端检验代码。新建Java Project ,取名为ZZaxisClient 。右键点击项目名,选择Properties-Java Build Path-Add Library-User Library-axis2
 
8 )新建package example.client 。建立TestClient.java ,代码如下。
TestClient.java
package example.client;
 
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
 
public class TestClient {
       private static EndpointReference targetEPR=new EndpointReference
        ("http://localhost:8080/axis2/services/HelloWorld");
       public static OMElement getSayHelloOMElement(){
              OMFactory fac=OMAbstractFactory.getOMFactory();
              OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
              OMElement method=fac.createOMElement("sayHello",omNs);
              method.setText("ZJ");
              return method;
       }
       public static void main(String[] args){
              try{
                     Options options=new Options();
                     options.setTo(targetEPR);
                     ServiceClient sender=new ServiceClient();
                     sender.setOptions(options);
                     OMElement sayHello=TestClient.getSayHelloOMElement();
                     OMElement result=sender.sendReceive(sayHello);
                     System.out.println(result);
              }
              catch(Exception axisFault){
                     axisFault.printStackTrace();
              }
       }
}
 
9 )测试,run TestClient.java as Java Application 。结果:
<hw:sayHelloResponse xmlns:hw="http://helloworld.com/"
xmlns:tns="http://ws.apache.org/axis2">
ZJHelloWorld!
</hw:sayHelloResponse>


1 HelloWorld 做了些什么?
HelloWorld 功能非常简单,在客户端输入你的姓名,本例中为ZJ 。参数传递到服务器端后,经过处理将返回name+"HelloWorld!" ,本例中为ZJ HelloWorld!
 
2 .服务器端文件HelloWorld.java
HelloWorld.java
package sample;
 
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
 
public class HelloWorld {
    // 读取client getSayHelloOMElement() 方法传递的参数in
       public OMElement sayHello(OMElement in){
        // in 转换为String
              String name=in.getText();
              String info=name+"HelloWorld!";
        // 创建response SOAP 包。
              OMFactory fac=OMAbstractFactory.getOMFactory();
        // OMNamespace 指定此SOAP 文档名称空间。
              OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
        // 创建元素sayHello ,并指定其在omNs 指代的名称空间中。
              OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
        // 指定元素的文本内容。
              resp.setText(info);
              return resp;
       }
}
 
3 services.xml 部署文件
services.xml
<?xml version="1.0" encoding="UTF-8"?>
// 下面定义服务名
<service name="HelloWorld">
<description>
 This is a sample Web Service.
</description>
// ServiceClass 指定Java Class 的位置,即实现服务的类。
<parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
// operation Java Class 中方法名对应。
<operation name="sayHello">
// messageReceiver 看下文注解。
 <messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
</operation>
</service>
 
注解: 消息交换模式。
目前Axis2 支持三种模式:In-Only Robust-In In-Out In-Only 消息交换模式只有SOAP 请求,而不需要应答;Robust-In 消息交换模式发送SOAP 请求,只有在出错的情况下才返回应答;In-Out 消息交换模式总是存在SOAP 请求和应答。本例使用In-Out 模式。
 
4 .客户端文件TestClient.java
TestClient.java
package example.client;
 
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
 
public class TestClient {
    // targetEPR 指定打包的Service .aar 文件 在容器中的物理位置。
       private static EndpointReference targetEPR=new EndpointReference
        ("http://localhost:8080/axis2/services/HelloWorld");
       public static OMElement getSayHelloOMElement(){
        // 创建request SOAP 包。
              OMFactory fac=OMAbstractFactory.getOMFactory();
        // OMNamespace 指定此SOAP 文档名称空间。
              OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
        // 创建元素sayHello ,并指定其在omNs 指代的名称空间中。
              OMElement method=fac.createOMElement("sayHello",omNs);
        // 指定元素的文本内容。
              method.setText("ZJ");
              return method;
       }
       public static void main(String[] args){
              try{
                     Options options=new Options();
                     options.setTo(targetEPR);
                     ServiceClient sender=new ServiceClient();
                     sender.setOptions(options);
                     OMElement sayHello=TestClient.getSayHelloOMElement();
            // 发出request SOAP
// 同时将得到的远端由sayHello 方法返回的信息保存到result
// 通过services.xml 能准确找到sayHello 方法所在的文件。
                     OMElement result=sender.sendReceive(sayHello);
              }
              catch(Exception axisFault){
                     axisFault.printStackTrace();
              }
       }
}
 
5 .Axis2 简介
Apache Axis2 Axis 的后续版本,是新一代的SOAP 引擎。Axis2 的主要特点有:
1 )采用名为 AXIOM AXIs Object Model )的新核心 XML 处理模型,利用新的XML 解析器提供的灵活性按需构造对象模型。
 
2 )支持不同的消息交换模式。目前Axis2 支持三种模式:In-Only Robust-In In-Out In-Only 消息交换模式只有SOAP 请求,而不需要应答;Robust-In 消息交换模式发送SOAP 请求,只有在出错的情况下才返回应答;In-Out 消息交换模式总是存在SOAP 请求和应答。
 
3 )提供阻塞和非阻塞客户端 API
 
4 )支持内置的 Web 服务寻址 (WS-Addressing)
 
5 )灵活的数据绑定,可以选择直接使用 AXIOM ,使用与原来的 Axis 相似的简单数据绑定方法,或使用 XMLBeans JiBX JAXB 2.0 等专用数据绑定框架。
 
6 )新的部署模型,支持热部署。
 
7 )支持HTTP SMTP JMS TCP 传输协议。
 
8 )支持REST (Representational State Transfer)
 
6 Axis2 支持的规范包括:
-SOAP 1.1 and 1.2
-Message Transmission Optimization Mechanism (MTOM), XML Optimized Packaging (XOP) and SOAP with Attachments
-WSDL 1.1, including both SOAP and HTTP bindings
-WS-Addressing (submission and final)
-WS-Policy
-SAAJ 1.1
有关Axis2 更加详细的介绍,可以访问Axis2 网站[url]http://ws.apache.org/axis2/[/url]