基于Tomcat5.0和Axis2开发Web Service应用实例【转】

上一篇 / 下一篇  2008-07-18 10:12:50

这几天都在研究WebService 了呵呵,Tomcat,Axis,Axis2Eclipse,WebService ,学习理论还得实践啊,下面的这个例子不错呵呵,至少让小娟明白什么是WEB服务,WEB服务如何发布调用,简单的不能再简单了呵呵,谁让我是菜鸟呢
 
有问题欢迎大家一起学习讨论呵呵。。。。

基于Tomcat5.0和Axis2开发Web Service应用实例
 
1.工作环境Eclipse
http://ws.apache.org/axis2/download/1_0/download.cgi页面下,下载AXIS2的Binary Distribution url:http://apache.justdn.org/ws/axis2/1_0/axis2-std-1.0-bin.zip和 war Distribution url:http://apache.justdn.org/ws/axis2/1_0/axis2-1.0-docs.zip。把这两个文件解压,比如解压缩的后得目录为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.检验安装
      启动Tomcat,在地址栏内输入http://localhost:8080/axis2/【如果不能够正常启动请参考其它文献
 
3.WebService中的HelloWorld
HelloWorld功能非常简单,在客户端输入你的姓名,本例中为Jack。参数传递到服务器端后,经过处理将返回name+"HelloWorld!",本例中为Jack HelloWorld!
1)新建一个动态web工程,取名ffhello,右键点击项目名,选择Properties-Java Build Path-Add Library-User Library-axis2。
 
2)新建package sample,建立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 ōmNs=fac.createOMNamespace("http://helloworld.com/","hw");
         //创建元素sayHello,并指定其在omNs指代的名称空间中。
               OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
         //指定元素的文本内容。
               resp.setText(info);
               return resp;
        }
}
 
3)建立META-INF文件夹 创建services.xml文件,代码如下。
services.xml
<?xml version="1.0" encoding="UTF-8"?>
<service name="HelloWorld">
<descrīption>
   This is a sample Web Service.
</descrīption>
<!-- ServiceClass指定Java Class的位置,即实现服务的类。 -->
<parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
<!-- operation 与Java Class中方法名对应。 -->
<operation name="sayHello">
   <messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
</operation>
</service>
 
4)将目录sample和目录META-INF组织如下(新建目录example)。
+-example
|-------- +-sample
     |------- HelloWorld.class【是生成的.class文件不是.java 文件目录】
|---------+-META-INF
   |------- services.xml
 
5)打包生成aar文件。
在命令符环境下,将当前目录转到example。
jar cvf HelloWorld.aar .//注意最后一个点,在当前目录下生成HelloWorld.aar。
 
6)在Eclipse中启动Tomcat,在地址栏下键入http://localhost:8080/axis2/。选择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 {
     // 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 ōmNs=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 ōptions=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();
               }
        }
}
 
9)测试TestClient.java ,在Eclipse中执行 run  --> as Java Application。结果:
 
<hw:sayHelloResponse xmlns:hw="http://helloworld.com/"
xmlns:tns="http://ws.apache.org/axis2">
JackHelloWorld!
</hw:sayHelloResponse>
 
4.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)。
 
5.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网站http://ws.apache.org/axis2/
 
 
 

TAG: WebService Eclipse Axis2

 

评分:0

我来说两句

日历

« 2024-04-09  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 14007
  • 日志数: 17
  • 建立时间: 2008-07-03
  • 更新时间: 2008-10-20

RSS订阅

Open Toolbar