XercesDOMParser
构造XercesDOMParser对象
为了用Xerces-C++解析XML文件,利用DOM,您可以创建XercesDOMParser类的一个实例。下面的例子显示了利用XercesDOMParser创建一个实例所需要的代码:
#include <xercesc/parsers/XercesDOMParser.hpp>
#include <xercesc/dom/DOM.hpp>
#include <xercesc/sax/HandlerBase.hpp>
#include <xercesc/util/XMLString.hpp>
#include <xercesc/util/PlatformUtils.hpp>
#if defined(XERCES_NEW_IOSTREAMS)
#include <iostream>
#else
#include <iostream.h>
#endif
XERCES_CPP_NAMESPACE_USE
int main (int argc, char* args[])
{
try
{
XMLPlatformUtils::Initialize();
}
catch (const XMLException& toCatch)
{
char* message = XMLString::transcode(toCatch.getMessage());
cout << "Error during initialization! :/n"
<< message << "/n";
XMLString::release(&message);
return 1;
}
XercesDOMParser* parser = new XercesDOMParser();
parser->setValidationScheme(XercesDOMParser::Val_Always);
parser->setDoNamespaces(true); // optional
ErrorHandler* errHandler = (ErrorHandler*) new HandlerBase();
parser->setErrorHandler(errHandler);
char* xmlFile = "x1.xml";
try
{
parser->parse(xmlFile);
}
catch (const XMLException& toCatch)
{
char* message = XMLString::transcode(toCatch.getMessage());
cout << "Exception message is: /n"
<< message << "/n";
XMLString::release(&message);
return -1;
}
catch (const DOMException& toCatch)
{
char* message = XMLString::transcode(toCatch.msg);
cout << "Exception message is: /n"
<< message << "/n";
XMLString::release(&message);
return -1;
}
catch (...)
{
cout << "Unexpected Exception /n" ;
return -1;
}
delete parser;
delete errHandler;
return 0;
}
XercesDOMParser所支持的特性
XercesDOMParser的行为依靠下面属性的值。所有下面属性值的设定需要利用"setter"方法(例如 setDoNamespaces) ,因此也要利用对应的的"getter"方法(例如 getDoNamespaces). 下面所呈述的仅仅是对这些支持特性的一个快速预览,更完全详细的内容请查阅API Documentation。
void setCreateEntityReferenceNodes(const bool)
true:在DOM树结构下创建EntityReference节点.这个EntityReference节点以及它的子节点只能被只读访问。
false:不会在DOM树结构下创建EntityReference节点.也没有EntityReference节点被创建, 只有这些节点所对应的全面扩展替代环境将被创建。
default:true
note:这个属性只能影响到DOM树结构中EntityReference节点的性质. 文档将总会包含所有的引用子节点实体。