使用 Axis2 和 JiBX 将 Java 类转换成 Web 服务,第 2 部分: 把 XML 转换成功能全面的 Web 服务

来源:百度文库 编辑:神马文学网 时间:2024/04/29 10:38:41
使用 Axis2 和 JiBX 将 Java 类转换成 Web 服务,第 2 部分: 把 XML 转换成功能全面的 Web 服务
[ http://blog.csdn.net/phantomhu/archive/2008/02/26/2121653.aspx ]
Apache Axis2 提供了好几种 XML 解决方案,可以轻松的开发功能强大的 Web 服务。Axis2 是实现 Web 服务的一个非常不错的选择。由于 Apache Axis2 和 Apache Geronimo duo 是免费而且开放源码的,因此可以考虑使用这两者。
在本系列的前一部分中,我向您介绍了在本系列两篇文章中使用到的 Java 类(参见参考资料)。我们通过 WSDL 将这些类作为 Web 服务公开,然后创建了一个 JiBX 定义描述,该定义描述将在文本中与 JiBX 数据绑定通信,来测试 Web 服务。在测试过程中,我们通过编译 JiBX 绑定类来创建包装类,使数据绑定类成为整个 Web 服务中的一个功能部分。
在继续深入开发之前,先要确保 /lib 中的所有的 JAR 文件(包括您在本系列文章第一部分中拷贝的 JiBX 文件)都在您的类路径下,并且在本文整个过程中要一直存在。同时,还需确保您的系统中已安装 Ant。Ant 可以从 Apache 下载获得(参见参考资料)。
让我们开始生成服务吧。
首先,需要使用 Axis2 生成服务,这样您就可以使用稍后创建的客户机来对它进行测试。在上篇文章开始之前,您应该已下载好必要的工具,并且设置好 AXIS2_HOME 环境变量。要开始创建服务,键入清单 1 中的命令。
java org.apache.axis2.wsdl.WSDL2Java
-uri C:appswebappsIBM-JiBXSimpleService.wsdl
-p com.ibm.devWorks.xml.simpleService -d jibx -s -ss -sd -ssi
-Ebindingfile ../binding.xml

这将为您创建最基本的服务!下列部分显示了各命令开关的注解:
-uri 开关告诉 Axis2 在哪能找到用于生成服务的 WSDL 文件。 -p 开关告诉 Axis2 服务要使用的 Java 包类。 -d jibx 选项指定 JiBX 数据绑定。 -s 开关指定只有同步(块)方法可用。 -ss 开关告诉 Axis2 要构建服务器端代码。 -sd 开关告诉 Axis2 要构建一个服务描述符(services.xml 文件)。 -ssi 开关是可选的,用于为服务实现 ( SimpleServiceSkeleton.java ) 创建一个 Java 接口。 -Ebinding 开关告诉 Axis2 在哪能找到 JiBX 定义说明文件。
现在已经有了一个 Web 服务,但是还没有任何定义。下一部分 将对服务进行定义。
只要成功调用了 Web 服务的一项操作,便会调用服务主干中的方法。Web 服务操作的实现代码包含在一个叫做 SimpleServiceSkeleton.java 的文件中(在本例中)。该文件位于 src/com/ibm/devWorks/xml/simpleService 目录,并且是空文件。对它进行定义,如清单 2 所示。
package com.ibm.devWorks.xml.simpleService;

public class SimpleServiceSkeleton implements SimpleServiceSkeletonInterface...{

    public  void OneWay
        (
         com.ibm.devWorks.xml.simpleService.OneWayRequest OneWayRequest
         )
    ...{
        System.err.println("Request data: " +
                           OneWayRequest.getRequestData());
    }

    public  com.ibm.devWorks.xml.simpleService.TwoWayResponse TwoWay
        (
         com.ibm.devWorks.xml.simpleService.TwoWayRequest TwoWayRequest
         )
    ...{
        System.err.println("Echo String : " +
                            TwoWayRequest.getEchoString());
        System.err.println("Booolean    : " +
                           TwoWayRequest.getBooolean());

        TwoWayResponse res = new TwoWayResponse();

        res.setEchoString(TwoWayRequest.getEchoString());
        res.setInvertedBoolean(!TwoWayRequest.getBooolean());

        return res;
    }
}

清单 2 中的代码含有两个方法,分别对应于本系列第一篇文章中讨论的两个操作(请参见参考资料)。第一个方法,OneWay,是单向(或者只输入)操作,它使用 OneWayRequest Java 对象作为输入参数,并且没有返回值。其实现仅仅是在屏幕上显示从客户机发送过来的内容。
第二个方法, TwoWay,使用 TwoWayRequest Java 对象作为输入,并且返回 TwoWayResponse 响应。这个方法首先显示传入请求对象的 echoString 和 booolean 字段,把响应中的 echoString 设置为请求中的 echoString 字段值,并把响应对象中的 invertedBoolean 值设置为请求对象中的 booolean 值的相反值(真则设为假,假则设为真)。然后把响应对象返回给客户机。
服务已经定义好了。接下来,我们将构建服务并创建 JiBX 数据绑定包装类。
在编译和创建 JiBX 数据绑定包装类之前,我们必须首先编译各类。要编译项目,键入:ant。
此时切换到 build/classes 目录创建包装类,键入:java -jar \lib\jibx-bind.jar ..\..\..\binding.xml。
您会发现四个新的 JiBX_* 类文件。包装类已经创建完成。现在重新打包 Axis2 服务存档文件,键入(与之前相同的目录):ant。
请注意,您不必构建代码两次。此处通过 Ant 可以知道代码已构建好,但是看到还有新文件,因此需要重新打包 Axis2 存档文件。
服务已经就绪,下节将在 Geronimo 上部署服务。
现在我们将部署刚刚创建和编译好的服务。如果 Geronimo 还未运行,应启动它,键入: java -jar /bin/server.jar。
现在将服务存档文件 build/lib/SimpleService.aar 拷贝到 /repository/default/axis2/1166439304031/axis2-1166439304031.war/WEB-INF/services 目录(需注意,准确的目录将有所不同)。
服务将很快自动部署好,现在一切已就绪,下节将创建一个客户机对其进行测试。
客户机允许您测试 Web 服务的功能和部署的正确性。同样,我们将使用 JiBX 数据绑定创建一个客户机,用于测试已部署好的 Web 服务。
键入清单 3 中的命令,生成 Web 服务。
java org.apache.axis2.wsdl.WSDL2Java
-uri C:appswebappsIBM-JiBXSimpleService.wsdl
-p com.ibm.devWorks.xml.simpleService
-d jibx -Ebindingfile ../binding.xml -s

上面的命令简单地创建了客户桩(client stub)代码。有关使用到的开关的解释,请参见生成服务。接下来,我们将定义真正的客户机代码,其代码将用于测试 Web 服务。
现在我们将编写用于测试 Web 服务已成功部署的代码,这会使用到我们刚刚使用 JiBX 数据绑定创建的客户桩。创建一个 src/com/ibm/devWorks/xml/simpleService/Client.java 文件,并对它进行定义,如清单 4 所示。
package com.ibm.devWorks.xml.simpleService;

public class Client...{
    public static void main(java.lang.String args[])...{
        try...{
            SimpleServiceStub stub =
                new SimpleServiceStub
                ("http://localhost:8080/axis2/services/SimpleService");

            oneWay(stub);
            twoWay(stub);
        } catch(Exception e)...{
            e.printStackTrace();
            System.out.println(" ");
        }
    }

    public static void oneWay(SimpleServiceStub stub)...{
        try...{
            OneWayRequest req = new OneWayRequest();

            req.setRequestData("Here is your requested data!");

            stub.OneWay(req);
        } catch(Exception e)...{
            e.printStackTrace();
            System.out.println(" ");
        }
    }

    public static void twoWay(SimpleServiceStub stub)...{
        try...{
            TwoWayRequest req = new TwoWayRequest();

            req.setEchoString("echo!... echo!");
            req.setBooolean(false);

            TwoWayResponse res = stub.TwoWay(req);

            System.out.println("Echo String : " +
                               res.getEchoString());
            System.out.println("Inv Boolean : " +
                               res.getInvertedBoolean());
        } catch(Exception e)...{
            e.printStackTrace();
            System.out.println(" ");
        }
    }
}

粗体显示了值得注意的代码。这个客户机首先初始化客户桩对象,然后将其传递给两个可用方法。第一个方法,oneWay,创建一个 OneWayRequest 对象,并将 requestData 字段的值初始化为 Here is your requested data!,然后数据将传送到服务器,由于是单向操作,因此没有返回。
第二个方法,twoWay,创建一个 TwoWayRequest 对象并初始化 echoString 和 booolean 字段。然后把请求对象发送给服务,并返回一个 TwoWayResponse 对象。根据清单 1 中定义的逻辑,响应对象中的 echoString 值应该匹配请求对象中 echoString 的值,并且响应对象中的invertedBoolean 应该与请求对象中的 booolean 的字段值相反,或者为真(在本例中)。
我们已经完成了客户机定义。现在我们只需编译 JiBX 绑定包装类,与前面构建服务中的编译一样。
在为客户机编译和创建 JiBX 数据绑定包装类之前,我们首先需要编译各类。要编译项目,键入:ant。
现在切换到 build/classes 目录创建包装类,键入:java -jar \lib\jibx-bind.jar ..\..\..\binding.xml。
我们应该注意到四个新创建的 JiBX_* 类文件,这与我们之前构建服务时一样。要重新打包包含客户机代码的 JAR 文件,键入(与之前相同的目录):ant。
这就全部完成了!最后剩下要做的就是完成测试。
现在,运行我们刚刚定义的客户机代码,我们应该在屏幕上看到正确的输出。在运行客户机之前,必须确保含有客户机代码(build/lib/SimpleService-test-client.jar)的 JAR 文件在您的类路径下。
要运行客户机,键入如下内容: java com.ibm.devWorks.xml.simpleService.Client。
我们应该能看到服务的输出,如图 1 所示。

请注意,正确的值已发送给服务。现在我们将检验发回客户机的值是否同样正确,这可以通过查看客户机的输出来完成,如图 2 所示。

一切都工作良好,您现在就可以施展 Jibx 魔法了!
现在,您应该算是一员 JiBX-Axis2 Web 服务开发人员了,能够使用 Axis2 和 JiBX 将您喜欢的一些 Java 类转换成 Web 服务。
在本系列的两篇文章中,我们通过 WSDL 将 Java 类公开,并使用 JiBX 定义描述将它们映射到 XML 数据。在这篇文章中,我们创建了一个实时的 Web 服务,这个服务是使用 Axis2 和 Geronimo 部署的。然后使用 Axis2 创建和运行客户机,来测试最终的实现。对于客户机和服务,我们都指定了 JiBX 数据绑定并分别为它们成功地创建了数据绑定包装类。
描述 名字 大小 下载方法
第 2 部分示例代码 x-jibx2-source.zip 24KBHTTP
学习
您可以参阅本文在 developerWorks 全球网站上的英文原文。
使用 Axis2 和 JiBX 将 Java 类转换成 Web 服务,第 1 部分:使用 XML 通过 Java 类定义 Web 服务(Tyler Anderson, developerWorks, 2007 年 5 月):在本系列的第 1 部分中,利用了已存在的 Java 类,并使用 WSDL 和 JiBX 定义描述定义了一个 Web 服务
JiBX 主页 了解更多有关在 SourceForge 项目中使用 JiBX 框架绑定 XML 数据与 Java 对象的知识。
XML 和 Java 技术:数据绑定,第 3 部分: JiBX 体系结构(Dennis Sosnoski,developerWorks,2003 年 7 月):在这篇文章中学习更多有关 JiBX 架构的知识,以及如何使用其极佳的性能和巨大的灵活性将 XML 与 Java 对象映射起来。
Apache Axis2 主页: 学习 Axis2 和 JiBX 是如何被整合到 Axis2 1.1 中去。
JiBX:从 Axis2 主页获取更多有关 JiBX 的信息。
Axis2:在 Axis2 主页学习、参与讨论、下载和发表想法。
Web 服务与 Axis2 体系结构(Eran Chinthaka,developerWorks,2007 年 2 月):获取更多有关 Axis2 架构和 Web 服务的知识。Axis2 是模块化、可扩展的,通过这篇文章了解它为什么能成为下一代的 Web 服务平台。
developerWork 中国网站 XML 专区:了解 XML 的方方面面。
IBM XML 认证:看看如何才能成为一名 IBM 认证的 XML 及相关技术的开发人员。
XML 技术文档库:developerWorks XML 专区提供了大量技术文章、提示、教程、标准以及 IBM 红皮书。
developerWorks 技术活动 和网络广播:随时关注技术的最新进展。
使用 Axis2 和 JiBX 将 Java 类转换成 Web 服务,第 2 部分: 把 XML 转换成功能全面的 Web 服务 使用 Axis2 和 JiBX 将 Java 类转换成 Web 服务,第 1 部分: 使用 XML 通过 Java 类定义 Web 服务 使用WebLogic将Web站点转换为Web服务(一) XML认证教程,第 10 部分: Web 服务 Web 服务内幕,第 2 部分:W3C Web 服务专题研讨会的概述 Web 服务内幕,第 2 部分:W3C Web 服务专题研讨会的概述 Web Services技术中的Axis2的使用及Web服务的发布 Web 服务与 Axis2 体系结构 XML 和 Java 技术:数据绑定,第 4 部分: 使用 JiBX 使用 AJAX 调用 SOAP Web 服务,第 1 部分: 构建 Web 服务客户机 Web 服务:Web 服务内幕,第 9 部分:研究问题 Web 服务:Web 服务内幕,第 10 部分:深入主题:可靠性和事务 Web 服务:Web 服务内幕,第 10 部分:深入主题:可靠性和事务 使用Java Web服务构建SOA Web 服务内幕,第 7 部分 WSFL 和递归组合 Web 服务内幕,第 4 部分 Java SE 6 新特性: XML API 与 Web 服务 Java SE 6 新特性: XML API 与 Web 服务 实现安全的AXIS Web服务,第1部分 Web 服务内幕,第 3 部分:Apache 和 Microsoft -- 良好的合作 基于服务的企业集成模式轻松入门,第 3 部分: Web services 和注册中心 基于服务的企业集成模式轻松入门,第 3 部分: Web services 和注册中心 XML 和 Java 技术:数据绑定,第 3 部分: JiBX 体系结构 Java将DOM文档和XML文件互相转换