基于C 的XML使能技术原理及应用精选.pdfVIP

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

第25卷第5期 暨南大学学报 (自然科学版) Vo1.25No.5 2004年 10月 JournalofJinanUniversity(NaturalScience) Oct.2004 基于C++的XML使能技术原理及应用 周智洪, 肖 璋,刘荣辉 (暨南大学电子工程系,广东广州510632) [摘 要] 探讨应用XML几项关键使能技术的概念、使用场合和基本使用方法,结合中国移动小 额支付平台中业务数据的交换所用到的XML解析、合成等技术进行了探讨,用C++语言,并利用 ORACLE公司提供的开发工具进行了实际的程序开发. [关键词]文档树模式;扩展标志言语简单API函数;扩展标志语言样式转换;扩展标志语 言模式处理;扩展标志语言类生成器 [中图分类号]1tr393 [文献标识码]A [文章编号] 1000—9965(2004)o5—0590一o6 XML(ExtensibleMarkupLanguage,扩展标志语言)是一种标准通用标记语言,即SGML的一 个子集.它定义了一套语义标记的规则,这些标记将文档分成许多部件并对这些部件定义为 标签.XML与HTML的最大不同就是用户根据定义出来的标签,可以按照实际的需要对需要 传送的文件进行充分的表达. 一 项开放的标准,XML及其相关技术的重要性在于基于这些标准建立的组件、库和应用 能够具有更好的可重用性和互操作性.为了有效地操作XML文档,必须调用大量的组件和实 用程序,开发者需要解析XML,针对DTD或XML模式来验证XML的有效性,用样式表来转换 XML,从数据中产生XML文档等等.下面分类具体论述XML解析、XSLT处理、XML模式处理 及XML类生成等关键技术的原理与应用. 1 xML解析 XML解析器是处理任何XML文件的第一关,分析出来的物件交给下游的应用程序作进一 步处理. 解析器遵循一定的标准.XML解析器按照如何回应(feedback)调用者的方式,可以分成两 大类:事件驱动类和对象模型类.前者的代表是sAX(SimpleAPIforⅪ垤L),后者的代表是DOM (DocumentObjectMode1).SAX的基本原理是,由接口的用户提供符合定义的处理器,XML分析 时遇到特定的事件,就调用处理器中特定事件的处理函数.而DOM的思想也称为 “基于树的 (treebased)”,因为其主要想法是一次性将一篇结构化文档全部解析,然后生成一个对象树 (objecttree)用以描述该文档.之后对于该文档的所有操作(如修改、查询等),均在该对象树上 进行. 但从实际的使用来说,不论是使用哪种方式的解析器,都大致经过以下几个步骤 【J: (1)初始化解析器:就是确定准备采用哪种方式解析xml文档.如果采用xmlinit(ecode, 【收稿151期]2003—09—30 [作者简介]周智洪(1976一),男,硕士研究生,研究方向:计算机与通信网络 第5期 周智洪等:基于C++的XML使能技术原理及应用 591 0,0,0,saxcb);ecode为返回的错误代码,saxcb表示SAX回调结构,即采用SAX方式进行解 析文档.如果用xmlinit(ecode,0,0,0,O),则解析器初始化为DOM方式. (2)解析:提供了两个方法来对XML文档解析.如果解析存储在外部文件中的文档,则用 方法xmlparse;例如:xmlparse(DOCUMENT,(oratext*)0,flag),DOCUMENT表示要解析的XML 文档的路径,0为缺省的文档编码,最后一个参数为解析器的行为标志位掩码;如果解析内存 缓冲区中的文档,则用xmlparsebuf,例如:xmlparsebuf(bur,sizeof(buf),(oratext*)0,flag). (3)调用DOM或SAX的API函数:如果采用DOM,调用解析器方法getDocument(),在内存 中建立XML文档树,返回DOM树的根(即文档节点的句柄),从根就可以访问树的其余部分. 如果你采用的是SAX接口,解析开始后就会触发相应的回调函数,你要做的就是在回调结构 xmlsaxcb指定你所需要

文档评论(0)

tazhiq2 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档