har文件解析工具_Tomcat 配置文件解析工具 Digester

c655d26e7c202f73d0652ac66c8ef08c.png

Digester 是一个依据 xml 配置文件动态构建 Java 对象树的工具,基于 SAX 解析器进行封装,它为 SAX 事件的处理提供了更高级和友好的接口,让开发更专注于要执行的处理,隐藏了 XML 元素详细的层次结构信息。

1. 对象堆栈

为了便于实现,内部使用堆栈存储创建的对象。当满足元素匹配模式时,按预设的处理规则操作栈中对象。

典型的创建对象处理逻辑是,触发创建新对象的规则,在遇到特定 XML 元素的开头时将其推送到栈顶;处理此元素的嵌套内容和属性时,该对象将保留在堆中;当遇到元素的末尾时,将它弹出。

Digester 提供的处理规则解决了这种设计的几个潜在问题:

  • 如何将正在创建的对象相互关联?SetNextRule 规则将栈顶对象作为参数传递给堆栈下一个顶层对象的命名方法(反之亦然),此规则可以轻松地在这些对象之间建立父子关系,一对一和一对多的关系也很容易构建。
  • 如何保留对第一个创建对象的引用?当遇到开始元素的结束标签时,所有对象从栈中弹出,但 parse() 方法会返回第一个创建的对象,也可以在解析前将某个应用程序对象的引用推送到堆栈,并手动设置和动态创建对象之间的父子关系。

2. 元素模式匹配

Digester 解析器的一个主要特性是自动确定正在解析的 XML 文档的元素层次结构,开发人员只需在解析过程中遇到某种嵌套元素排列时,决定要执行哪些函数。元素匹配模式,确认的就是执行函数也就是规则。

一个非常简单的元素匹配模式是一个简单的字符串,如"a"。只要在 XML文档中遇到顶级元素 ,无论它发生多少次,都会匹配此模式。请注意,嵌套的 元素将不匹配此模式。

比较复杂的是匹配嵌套元素,如 "a/b",当找到嵌套在顶级 元素内的 元素时,将匹配此模式。同样,这种匹配可以根据需要多次发生,具体取决于要解析的XML文档的内容。也可以使用多个斜杠来定义要匹配的任何所需深度的层次结构。

例如,假设已注册与 "a

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值