XMLlite
XMLlite是Windows操作系统提供的了一组服务,用户可以使用C/C++语言和其它微软的开发工具开发基于XML的本机应用程序。它支持XML 1.0、SAX、XSLT 1.0,并提供了包括XSD和XDR在内的XML Schema 语言、XMLHttpRequest、XPath等技术。
XMLlite是前向读写XML文件,不缓冲或者建立XML文件的结构。
XMLlite并不是COM组件,因此不能给VB.Net、VBScript等使用。XMLlite使用的COM技术有:
- XMLlite的接口使用IUnknown接口的方式来做生存期管理;
- 数据存储使用了COM的IStream;
- 接口对象的管理使用ATL的CComPtr。
使用这些COM资源时应该注意用后调用Release函数或者CComPtr的RAII。
系统安装
从2006年10月开始,XMLlite运行时文件Xmllite.dll,包含在下述操作系统或软件安装中:[1]
- Windows Server 2008及更高版本
- Windows Vista及更高版本
- Windows XP with Service Pack 3及更高版本
- Windows Server 2003 with Service Pack 2及更高版本
- Microsoft Internet Explorer 7及更高版本
SAX
XmlLite的类是映射到.NET Framework实现的:[2]
XmlLite | .NET Framework |
---|---|
IXmlReader interface | XmlReader class |
IXmlWriter interface | XmlWriter class |
XmlReaderProperty enum | XmlReaderSettings class |
XmlWriterProperty enum | XmlWriterSettings class |
CreateXmlReaderInputWithEncodingCodePage CreateXmlReaderInputWithEncodingName | |
XmlNodeType enum | XmlNodeType enum |
IXmlReader
用于读入、分析XML的接口。
CComPtr<IXmlReader> reader;
COM_VERIFY(::CreateXmlReader(__uuidof(IXmlReader),
reinterpret_cast<void**>(&reader),
0));
CComPtr<IStream> stream;
// Using OS API to create stream object here...
reader->SetInput(stream);
HRESULT result = S_OK;
XmlNodeType nodeType = XmlNodeType_None;
while (S_OK == (result = reader->Read(&nodeType)))
{
// 已从流中成功读取一个节点。节点的属性自动存储在内部集合中,因此可以使用MoveToAttributeByName方法按名称将读取器移动到特定的属性。
for (HRESULT result = reader->MoveToFirstAttribute();S_OK == result;result = reader->MoveToNextAttribute())
{
// 成功枚举当前节点的一个属性
}
}
//返回 S_FALSE 以指示已到达流的结尾处
IXmlResolver
解析外部实体。编写对IXmlResolver接口实现并用IXmlReader的SetProperty方法设置XmlReaderProperty_XmlResolver属性,以指示读取器使用自编的外部实体解析程序。
IXmlReaderInput
创建XML读取器输入对象并指定文本编码。可用两个函数创建该对象:
- CreateXmlReaderInputWithEncodingCodePage
- CreateXmlReaderInputWithEncodingName
IXmlWriter
CComPtr<IXmlWriter> writer;
COM_VERIFY(::CreateXmlWriter(__uuidof(IXmlWriter),
reinterpret_cast<void**>(&writer),
0));
CComPtr<IStream> stream;
// Use OS API to create stream object here
writer->SetOutput(stream);
writer->SetProperty(XmlWriterProperty_Indent, TRUE);//写入之前,可以修改写入器属性,如缩进 XML 输出。
//IXmlWriter提供了许多 WriteXXX 方法,用于写入各种节点类型、属性和值。
IXmlWriterLite
IXmlWriterOutput
用此对象指定输出的XML的文本编码不是UTF-8的其他设定。可用两个函数创建本对象:
- CreateXmlWriterOutputWithEncodingCodePage
- CreateXmlWriterOutputWithEncodingName
C语言使用
需要在源程序中加入这行:
#include <xmllite.h>
#pragma comment(lib,"xmllite.lib")
Visual Basic使用
VBScript使用
参考文献
- ^ ([//web.archive.org/web/20161220084118/https://msdn.microsoft.com/EN-US/library/ee388577(v=VS.85,d=hv.2).aspx 页面存档备份,存于互联网档案馆) Installing XmlLite in MSDN]
- ^ Kenny Kerr : XmlLite-A Small And Fast XML Parser For Native C++, published in MSDN Magazine, April 2007.