基于JavaXML解析与反射设计模式.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于JavaXML解析与反射设计模式

基于JavaXML解析与反射设计模式   摘要:随着计算机时代的蓬勃发展,Internet的普及给社会以及人民的生活带来了巨大的影响。与此同时,B/S结构的多系统相互访问技术应时代的发展也如雨后春笋般不断涌现出来,相应的多系统间数据交互产生的问题也是越来越多,XML的数据解析与系统业务逻辑如何融合就是其中比较难以解决的问题之一。   关键词:XML Java   在web中,多系统间数据交互一般使用WebService技术,它是一种构建应用程序的普遍模型,可以在任何支持网络通信的操作系统中实施运行;它是一种新的web应用程序分支,是自包含、自描述、模块化的应用,可以发布、定位、通过web调用。WebService是一个应用组件,它逻辑性的为其他应用程序提供数据与服务。各应用程序通过网络协议和规定的一些标准数据格式(Http,XML,Soap)来访问WebService,通过WebService内部执行得到所需结果。Web Service可以执行从简单的请求到复杂商务处理的任何功能。一旦部署以后,其他WebService应用程序可以发现并调用它部署的服务。WebService的主要目标就是跨平台的可互操作性。为了达到这一目标,WebService完全基于XML、XSD等独立于平台、独立于软件供应商的标准,是创建可互操作的、分布式应用程序的新平台。   Java作为现下最流行的可撰写的跨平台应用软件的面向对象的程序设计语言,在多系统数据交互这方面具有先天的优势。它具有动态性,它的设计目标之一是适应于动态变化的环境。Java程序需要的类能够动态的被载入到运行环境,也可以通过网络来载入所需要的类。安全性,Java通常被用在网络环境宏,为此,Java提供了一个安全机制加以防恶意代码的攻击。除了Java语言具有的许多安全特性以外,Java对通过网络下载的类具有一个安全防范机制(类ClassLoader),如分配不同的名字空间以防替代本地的同名类、字节代码检查,并提供安全管理机制(类SecurityManager)让Java应用设置安全哨兵。多元性,作为现下最流行的语言,应用之广泛,资源之充足都是现今流行语言中的佼佼者,在行业和企业信息化、电子政务及办公自动化、嵌入式设备及消费类电子产品、辅助教学等领域发挥着其多元性的优势。   XStream可以完美转换XML,与以往的解析XML工具dom相比,XStream是一个易用的、开源的库,使用起来简单、小巧,容易理解,可以轻易的将Java对象和xml文档相互转换,而且可以修改某个特定的属性和节点名称。就是由于与Java对象的完美转换才更贴近于面向对象的设计思想,让开发人员更易于使用,更易于过度解析XML与项目业务逻辑之间的联系。XStream不仅对XML的转换非常友好,而且提供annotation注解,可以在avaBean中完成对xml节点、属性的描述。以及对JSON也支持,只需要提供相关的JSONDriver就可以完成转换。使用XStream序列化的类不需要实现Serializable接口。XStream是一种序列化工具而不是数据绑定工具,就是说不能从XML或者XML Schema Definition (XSD)文件生成类。   和其他序列化工具相比,XStream 有三个突出的特点:①XStream不关心序列化/逆序列化的类的字段的可见性。②序列化/逆序列化类的字段不需要getter和setter 方法。③序列化/逆序列化的类不需要有默认构造函数。   不需要修改类,使用 XStream就能直接序列化/逆序列化任何第三方类。XStream也有其欠缺的地方,当XML过大时用XStream解析就略显笨重,SAXParser可以解决这个问题,SAXParser在处理XML时非常类似于流媒体的方式,分析能够立刻开始,而不是等待所有的数据被处理。而且程序只是在读取数据时检查数据,因此不需要将数据存储在内存中。这对于处理大型XML来说是个巨大的优点,事实上,程序甚至不必解析整个文档,它可以在某个条件得到满足时停止解析,这种读取方式比XStream与DOM都要快上许多。所以在读取大型XML时可以把XStream与SAXParser结合起来使用,用SAXParser读取整个XML把核心数据部分让XStream来解析成JavaBean,这样既解决了大数据的问题又利用了XStream快速转化JavaBean的优点。   为了利于多系统间数据交互的一致性与标准性,需要在开发项目初期就要制定好数据交互的XSD标准( XML Schemas Definition )。XSD描述了XML文档的结构。可以用一个指定的XSD来验证某个XML文档,以检查该XML文档是否符合其要求。文档设计者可以通过XSD指定一个XML

文档评论(0)

189****7685 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档