用JAVA和XML构建分布式系统

  可扩展标记语言(XML)作为一种简单的、中性的、易读的数据表示形式已经变得越来越流行,许多软件厂商宣布的“支持XML",意味着他们的产品将能生成或处理XML数据。XML也被看作再企业间交换数据最佳格式。它允许企业在所交换的数据的XML的文档类型定义(Document Type DefinitionsDTDs)或模式(Schema)上取得一致。这些DTDsSchema是独立于企业使用的数据库模式的。

    用研究在不同计算机之间通讯与处理XML数据的分布式系统的构建方法,主要是运行在不同的虚拟机上的JAVA应用之间的XML通讯。

 

  XML通讯

  万维网协会(World Wide Web Consortium, W3C)在XML规范中定义了XML的语法和语义。为了处理XML数据,XML文档必须经过解析。W3C定义了文档对象模型(DOM),它是应用程序员处理XML数据的接口。DOM已经有包括JAVA在内的许多语言的实现。JAVA应用程序可以通过DOM API来访问XML数据。XML解析器将产生XML文档的DOM表示。  

    处理器代码将DOM代表的XML数据传给发送者。发送者是与接收者进行XML数据通讯的JAVA代码。接收者JAVA代码来接受XML数据,产生DOM表示的数据并把它传送给另一个处理器。简而言之,发送者和接收者抽象了DOM表示的XML数据的通讯。

  发送者和接收者不是在同一个JAVA虚拟机上执行的。他们是通过分布式系统的构件来相连的。无论是接收者还是发送者都既是客户端又是服务器端,两者的数据传输都是双向的。

 

Xbeans

        就像将要看到的一样,在本文中描述的发送者和接收者的三种实现方法都都是通过Xbeans来实现。Xbeans是一种接受XML数据作为输入,处理这个输入然后向下一个Xbeans输出XML结果的软件构件。Xbeans的输入输出都是XMLDOM文档,亦即传送给Xbeans的不是需要XML解析器解析的字符串,而是通过W3C的标准DOM API解析成了文档对象。图2说明了一个Xbeans

  XbeansJavaBeans,支持封装、重用、连接和客户化Java代码。通过适当的一些XbeansJavaBeans的设计工具,我们就能编很少的代码构建非常有用的分布式应用。 XbeansIBMXMLJAVA开发工具包而来,在其上作了少量修改以便更适合分布式的应用。Xbeans能够从www.Xbeans.org的开放源码项目中免费获得。

 

实现发送方和接收方

    下面将介绍用JAVA实现发送者和接收者的一种方法:  用标准的web 服务器

这种方法将只是简单的将XML作为文本发送给远程计算机上的web服务器。发送方必须将DOM表示的XML转化为文本来与接收方进行通讯。然后,接受方必须将文本还原为DOM表示,如图3

  以下代码段用HTTP来实现发送者。这里用到了IBM Java开发包中的DOMWriter类来实现DOM表示到文本XML表示的转换。

public void documentReady(DOMEvent evt)

throws XbeansException {

try {

URL receiver = new URL (getRemoteURL ());

URLConnection receiverConnection = receiver.openConnection();

receiverConnection.setDoOutput(true);

//向发送者打开一个输出流然后发送文本形式的XML数据

OutputStream out = receiverConnection.getOutputStream();

DOMWriter writer = new DOMWriter();

writer.setPrintWriter(new PrintWriter(out));

writer.documentReady(

new com.ibm.xml.xpk4j.dom.DOMEvent( this,evt.getDocument()));

out.close(); // 为结果打开一个输入流

BufferedReader in = New BufferedReader(

new InputStreamReader(receiverConnection.getInputStream()));

// 处理结果:"OK" 表示成功;"Exception" 表示输入流串行化异常

...

in.close();

} catch (Throwable e) {

e.printStackTrace(System.err);

}

 

  注意到以上的documentReady()方法用remoteURL属性得到服务器上的CGI脚本的URL。为了与HTTP兼容,CGI脚本类用字符串”Content-type: text/html"封装接收者的输出。这个脚本然后调用服务器上的the receiverMain()方法。 Main()函数只是简单的实例化接收者然后调用其receiveDocument()方法。   

import org.xbeans.communication.stdio.receiver.*;

public class receiverMain {

static Bean theReceiver = new Bean();

public static void main(String[] args) {

theReceiver.receiveDocument();

}

}

  最后receiveDocument()方法的代码段将重新生成DOM表示以便进一步处理。这里用到了IBMXML解析器。   

DOMParser parser = new DOMParser(); // 构造解析器

try { // 调用解析器

parser.parse(new InputSource(System.in));

} catch (Throwable e) {

throw new XbeansException("","receiver","io error parsing incoming document",

"io error parsing incoming document "+e);

}

//将文档传向下一个bean

DOMListener.documentReady(new DOMEvent(this,parser.getDocument()));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值