在SOA架构中,程序员经常使用XML在应用程序之间交换结构化和半结构化的数据。XML及其相关技术—文档对象模型(DocumentObjectModel,DOM)、XPath、HTTP、XQuery和可扩展样式表语言转换(ExtensibleStylesheetLanguageTransformations,XSLT)—为快速应用程序开发提供了一个强大的环境。构建在这些技术之上的应用程序将占用更小的内存空间,需要更低的维护成本,同时又拥有更高的品质和灵活性。 DB2和其他关系数据库的XML方面的特性已经相当成熟,因此除了存储和管理关系数据之外,它们还是存储和管理XML数据的理想选择。DB29XML支持(称为pureXML)提供了以纯XML的形式(换句话说,就是带注释的、树型的分层存储)存储XML的能力。在DB29中,XML数据可以用XML模式索引,可以从关系数据组合而成,可以分解为关系数据,可以查询和转换,可以独立发布,或者通过混合使用SQL/XML和XQuery与关系数据组合起来。 Web浏览器也正在为客户机脚本提供更多的功能来有效地处理XML。通过使用异步javascript和XML(AsynchronousjavascriptandXML,Ajax),Web页面现在可以直接对应用服务器进行远程过程调用,并且可以在任何返回的XML数据上使用DOMAPI。 本文将展示如何利用DB2XML、Ajax和PHPHypertextPreprocessor(PHP)提供的功能来编写简单的基于XML的应用程序。通过示例场景的帮助,您将学习如何在javascript中调用PHP应用程序;如何使用DOM和SimpleXMLAPI修改XML数据;如何将XML从客户机传送到应用程序再到数据库;以及如何创建PHPWeb服务来使用SQL/XML和XQuery发布关于XML数据的报告。 XML优点 大多数应用程序都用于创建、存储、操纵和呈现业务数据。对象包装是指将业务数据绑在一起,使业务逻辑更容易处理它们。这些包装器对象的很多功能都是根据关系和格式化规则来提供业务数据的结构,并使业务逻辑能够操纵、发布和串行化封装的数据。 图1.基于对象包装器的应用程序 图1阐释了使用对象包装器的一个示例人寿保险应用程序。每个方框表示一个对象,每个对象至少有:
·一个构造函数 ·Getter和Setter方法 ·验证代码 ·内部对象层次的串行化 这些对象与实际的业务逻辑没有关系。对象包装是为了使业务逻辑更容易管理业务数据。包装数据所需的代码比业务逻辑要多得多。更多的代码将导致更多的bug、更大的固定性、更多的维护和更高的成本。 如果对象中的数据变量可以格式化为XML结构,并且对象的主要作用是将这些数据暴露给业务逻辑并让业务逻辑操纵它们,那么可以用DOM代替对象。 图2.基于XML的应用程序 图2展示了一个使用XML和DOM包装器的示例保险应用程序。图1中的所有数据包装器对象都用一个DOM对象代替。业务数据是用XML建模的,DOM提供了必要的API来:
·创建新的XML对象。 ·更新XML对象的值。 ·导航XML对象。 ·使用XPath在对象层次中搜索。 ·串行化和反串行化XML对象层次(换句话说,就是内建持久性)。 通过使用XML,可以避免使用大多数用于管理业务数据的包装器对象。应用程序将变得更加简洁,并且更多地将重点放在业务逻辑上,而不是数据管理上。 XML和架构 将XML引入架构中可以为表示业务数据带来一种标准化的方式。XML可以提供数据的结构;XML模式施加结构和格式化规则;DOMAPI和XQuery、XPath及XSLT之类的语言使业务逻辑可以有效地操纵、发布和串行化数据。由于业务数据的XML表示在客户机、中间层和数据库中都是一致的,因此操纵这些对象的代码也是类似的。 我将展示如何在三层环境中构建基于XML的应用程序,这个三层环境由以下几个部分组成: ·Web客户机:AsynchronousjavascriptandXML(Ajax),DOM ·应用服务器:PHP和SimpleXML ·数据库:DB29和SQL/XML,XQuery 基于ACORD人寿数据模型的场景 我们来考虑一个简单的人寿保险场景,在这个场景中,首先创建一个表示新保单的XML文档,然后查询和操纵这个文档,另外还将这个文档从一层移动到另一层。这个文档基于合作运营研究与发展协会(AssociationforCooperativeOperationsResearch&Development,ACORD)用于人寿保险规范的XML,它定义了健康保险和年金保险需要交换的数据。 为了申请一个新的保险,客户需要提供一些基本信息。部分信息是在一个PHP应用程序中填写的,还有一部分是在客户机浏览器中填写的。然后,保单存储在一个DB2XML列中。在DB29中,XML类型的列在内部将XML数据存储为一棵解析后的树,与关系数据存储在不同的地方。这种方法是DB29特有的,更早的DB2版本则使用关系存储基础设施来存储XML。 下面是保单XML文档在客户机与应用程序之间的流程: ·在Web客户机中,客户更新页面并单击Submit。 ·Web客户机向PHP发出一个XMLHTTP请求,以获得新的空白保单文档。 ·PHP应用程序打开一个空白的保单文档,用一个全局惟一标识符(GUID)更新它,然后将该文档返回给Web客户机。 ·Web客户机使用Ajax捕捉返回的事件,并检索XMLDOM,然后用Web页面中输入的信息填充该文档。 ·Web客户机使用XMLHTTP将更新后的XML发送给PHP应用程序。
|