Digester 在tomcat启动的时候利用SAX2来解析server.xml. SAX - Simple API for XML, 是一种基于java的xml API。可以看篇文章了解更多:[url]http://www.iteye.com/topic/181865 [/url]
[quote]
SAX解析器采用了基于事件的模型,它在解析XML文档的时候可以触发一系列的事件,当发现给定的tag的时候,它可以激活一个回调方法,告诉该方法制定的标签已经找到。SAX对内存的要求通常会比较低,因为它让开发人员自己来决定所要处理的tag.特别是当开发人员只需要处理文档中所包含的部分数据时, SAX这种扩展能力得到了更好的体现。但用SAX解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。 [/quote]
典型的事件有:
start document, end document
start element, end element
characters
举例说明一下:
比如这样一个xml文件
<?xml version="1.0"?>
<doc>
<para>Hello, world!</para>
</doc>
SAX接口在解析的时候会依次出发一系列的事件:
start document
start element: doc
start element: para
characters: Hello, world!
end element: para
end element: doc
end document
好了,下面开始分析一下Digest类。
Digest类处理一个XML输入流,它根据一系列的嵌入的[b]模式[/b]匹配在parse之前加入的[b]rules[/b]来执行[b]解析[/b]工作。
Catalina 最终利用 createStartDigester方法创建一个解析Server的digester来生成一个org.apache.catalina.core.StandardServer 的实例。
[quote]
SAX解析器采用了基于事件的模型,它在解析XML文档的时候可以触发一系列的事件,当发现给定的tag的时候,它可以激活一个回调方法,告诉该方法制定的标签已经找到。SAX对内存的要求通常会比较低,因为它让开发人员自己来决定所要处理的tag.特别是当开发人员只需要处理文档中所包含的部分数据时, SAX这种扩展能力得到了更好的体现。但用SAX解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。 [/quote]
典型的事件有:
start document, end document
start element, end element
characters
举例说明一下:
比如这样一个xml文件
<?xml version="1.0"?>
<doc>
<para>Hello, world!</para>
</doc>
SAX接口在解析的时候会依次出发一系列的事件:
start document
start element: doc
start element: para
characters: Hello, world!
end element: para
end element: doc
end document
好了,下面开始分析一下Digest类。
Digest类处理一个XML输入流,它根据一系列的嵌入的[b]模式[/b]匹配在parse之前加入的[b]rules[/b]来执行[b]解析[/b]工作。
Catalina 最终利用 createStartDigester方法创建一个解析Server的digester来生成一个org.apache.catalina.core.StandardServer 的实例。
235

被折叠的 条评论
为什么被折叠?



