用Digester简化XML文档处理(1)

原创 2005年05月30日 12:41:00
Digester框架属于Jakarta Commons,它以规则和模式为基础处理XML文档。与SAX和DOM之类的标准API相比,Digester不涉及太多的细节问题,非常适合于对XML文档进行简单的处理。 
在Java和XML开发中,一个常见的任务是把XML文档转换成对应的Java Bean对象的层次结构。人们经常用标准的SAX和DOM API来完成这个任务。虽然这两种API都很强大和灵活,但对于某些简单的任务来说,它们显得操作层次太低,也就是说,涉及了太多的细节问题。Jakarta Digester框架能够很好地满足这类场合的需要。 
Digester框架简介 

Jakarta的Digester框架从Struts框架发展而来,原先被用来处理struts-config.xml配置文件,但很快人们认识到它有着更广泛的用途,把它转入了Jakarta Commons项目。Jakarta Commons的目标是提供一个“可重用Java组件的仓库”。Digester最新的版本是1.3,于2002年8月13日发布。 
Digester框架允许开发者指定一组动作,当解析器在XML文档中发现某些特定的简单模式时动作被执行。Digester框架带有10个预定义的规则(Rule),涵盖了unmarshalling XML(例如创建Bean或设置Bean属性)的大多数需求( marshalling的原意是指“配制整齐,编组列车”,marshalling是在内存中为Java对象生成XML描述文档的过程,而unmarshalling是指把XML形式的描述转换到可用Java代码操作的对象的过程,我们称之为“反配制”),但必要时用户可以定义和实现自己的规则。 
在本文的例子中,我们将反配制下面这个XML文档: 
<?xml version="1.0"?>
<catalog library="somewhere">
  <book>
    <author>Author 1</author>
    <title>Title 1</title>
  </book>
  <book>
    <author>Author 2</author>
    <title>His One Book</title>
  </book>
  <magazine>
    <name>Mag Title 1</name>
    <article page="5">
      <headline>Some Headline</headline>
    </article>
    <article page="9">
      <headline>Another Headline</headline>
    </article>
  </magazine>
  <book>
    <author>Author 2</author>
    <title>His Other Book</title>
  </book>
  <magazine>
    <name>Mag Title 2</name>
    <article page="17">
      <headline>Second Headline</headline>
    </article>
  </magazine>
</catalog>

下面是Bean的代码。注意使用Digester框架时,Bean类必须定义成public。
import java.util.Vector;
public class Catalog {
  private Vector books;
  private Vector magazines;
  public Catalog() {
    books = new Vector();
    magazines = new Vector();
  }
  public void addBook( Book rhs ) {
    books.addElement( rhs );
  }
  public void addMagazine( Magazine rhs ) {
    magazines.addElement( rhs );
  }
  public String toString() {
    String newline = System.getProperty( "line.separator" );
    StringBuffer buf = new StringBuffer();
    buf.append( "--- Books ---" ).append( newline );
    for( int i=0; i<books.size(); i++ ){
      buf.append( books.elementAt(i) ).append( newline );
    }
    buf.append( "--- Magazines ---" ).append( newline );
    for( int i=0; i<magazines.size(); i++ ){
      buf.append( magazines.elementAt(i) ).append( newline );
    }
    return buf.toString();
  }
}
//===================================================
public class Book {
  private String author;
  private String title;
  public Book() {}
  public void setAuthor( String rhs ) { author = rhs; }
  public void setTitle( String rhs ) { title = rhs; }
  public String toString() {
    return "Book: Author='" + author + "' Title='" + title + "'"
  }
}
//===================================================
import java.util.Vector;
public class Magazine {
  private String name;
  private Vector articles;
  public Magazine() {
    articles = new Vector();
  }
  public void setName( String rhs ) { name = rhs; }
  public void addArticle( Article a ) {
    articles.addElement( a );
  }
  public String toString() {
    StringBuffer buf = new StringBuffer( "Magazine: Name='" + name + "' ");
    for( int i=0; i<articles.size(); i++ ){
      buf.append( articles.elementAt(i).toString() );
    }
    return buf.toString();
  }
}
//===================================================
public class Article {
  private String headline;
  private String page;
  public Article() {}
  public void setHeadline( String rhs ) { headline = rhs; }
  public void setPage( String rhs ) { page = rhs; }
  public String toString() {
    return "Article: Headline='" + headline + "' on page='" + page + "' "
  }
}

使用Apache的Digester来解析XML文档

package com.wckj.entity; import java.io.ByteArrayInputStream; import java.io.IOException; import o...

使用Digester解析XML文档示例

  • 2012年07月25日 09:06
  • 6KB
  • 下载

Digester解析xml文档

依赖apache的四个包: commons-digester-2.1.jar commons-logging-1.1.1.jar commons-beanutils-1.8.3.jar com...

java--DOM对xml文档的解析1

关键词-解释:DOM-Document Object Model-文档对像模型。是w3c组织处理xml的一种方式。        特点:                 一次将所有数据全部加载到内存...
  • xanlv
  • xanlv
  • 2016年09月15日 16:39
  • 726

1dom4j api 详解++2dom4j生成或解析xml文档

dom4j api 详解及dom4j生成或解析xml文档 dom4j api 详解   1、DOM4J简介     DOM4J是 dom4j.org 出品的一个开源 XML 解析包。...

windows mobile 如何读写XML文档 1

用C#如何读写xml文件呢首先要知道在PC机里是如何读取和写入XML ..... XML是一项热门的技术。它之所以能够引起人们的兴趣,一个主要的原因在于它十分的简单,人们可以很容易地理解和使用它。每一...
  • qqxinxi
  • qqxinxi
  • 2011年04月24日 02:11
  • 850

dom4j处理xml文档说明

  • 2013年02月20日 14:00
  • 48KB
  • 下载

Flash处理XML文档数据教程

  • 2014年02月17日 18:27
  • 49KB
  • 下载

java中XML文档解析1(Dom)

解析XML的方式分为以下几种: JAXP(JavaApi for Xml Programming) – sun公司的一套操作XML的API. DOM解析-一次性的将数据全部装入内存。SAX解析-边读...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用Digester简化XML文档处理(1)
举报原因:
原因补充:

(最多只允许输入30个字)