Digester 解析 XML

2 篇文章 0 订阅

为了满足将XML转换为JavaBean的特殊需求,Apache旗下的一个名为Digester的工具为我们提供了这么一个选择。

将XML转化为JavaBean存储在内存当中, 解析的关键在于用以匹配XML的模式以及规则等

以解析下面XML为例介绍Digester

<root>
   <person>
       <username>张三</username>
       <age>22</age>
       <idcard>320105197903082216</idcard>
       <address>北京海淀</address>
       <note></note>
   </person>
   <person>
       <username>李四</username>
       <age>20</age>
       <idcard>610114197601064931</idcard>
       <address>上海徐汇</address>
       <note></note>
   </person>
   <person>
       <username>王五</username>
       <age>26</age>
       <idcard>130105198710113660</idcard>
       <address>广州天河</address>
       <note></note>
   </person>
</root>

此XML文件分两层结构,分别为:

  • <root>节点,下面包含多个<person>节点

  • <person>节点,下面包含各信息节点,如<username>、<age>

我们的目的是把<person>节点里面的信息提取出来,所以可以把person看做一个对象

里面的信息节点就是对象的属性

Person类如下:

public class Person {
    private String username;
    private String age;
    private String idcard;
    private String address;
    private String note;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }

    public String getIdcard() {
        return idcard;
    }

    public void setIdcard(String idcard) {
        this.idcard = idcard;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    public String getNote() {
        return note;
    }

    public void setNote(String note) {
        this.note = note;
    }

    public String toString() {
        StringBuffer buf = new StringBuffer();
        buf.append("username: " + username);
        buf.append(", age: " + age);
        buf.append(", idcard: " + idcard);
        buf.append(", address: " + address);
        buf.append(", note: " + note);

        return buf.toString();
    }
}

创建Root类,用来保存Person对象

public class Root {
    private List persons;

    public Root() {
        persons = new ArrayList();
    }

    /**
     * 把Root下面的Person添加到一个集合中
     *
     * @param per
     */
    public void addPerson(Person per) {
        persons.add(per);
    }

    /**
     * 获取Person对象集合
     *
     * @return
     */
    public List getPersons() {
        return persons;
    }
}

创建DigesterDriver类,对XML进行解析

import com.home.bean.Person;
import com.home.bean.Root;
import org.apache.commons.digester3.Digester;
import org.xml.sax.SAXException;
import java.io.File;
import java.io.IOException;
import java.util.List;

public class DigesterDriver {
    public static void main(String[] args) {
        // 定义要解析的 XML 的路径,并初始化工具类
        File input = new File("person.xml");
        Digester digester = new Digester();
        digester.setValidating(false);
        // 添加Root对象, 对应 XML中的<root>节点
        digester.addObjectCreate("root", Root.class);
        // 添加Person对象, 对应 XML中的<person>节点
        digester.addObjectCreate("root/person", Person.class);

        //添加Person对象下的各个属性,对象<person>节点下的各个信息节点
        digester.addBeanPropertySetter("root/person/username", "username");
        digester.addBeanPropertySetter("root/person/age", "age");
        digester.addBeanPropertySetter("root/person/idcard", "idcard");
        digester.addBeanPropertySetter("root/person/address", "address");
        digester.addBeanPropertySetter("root/person/note", "note");

        // 通过调用 JavaBean 的 addPerson() 方法来把多个 person 加到一个集合中
        digester.addSetNext("root/person", "addPerson");

        try {
            // 进行解析
            Root root = (Root) digester.parse(input);
            List persons = root.getPersons();

            for (int i = 0; i < persons.size(); i++) {
                Person p = (Person) persons.get(i);
                System.out.println(p);
            }
        } catch (IOException e) {
            e.printStackTrace();
        } catch (SAXException e) {
            e.printStackTrace();
        }
    }
}

上述代码展示了Digester处理XML 的一些基本要点,主要是说明了一些模式以及规则的匹配。

简言之,Digester就是一种用来把一个XML转化为一个与该XML结构类似的 JavaBean。

你可以把XML根元素想象成一个JavaBean, 该根元素的attribute就是这个JavaBean的各种 Field,

当该根元素有其他子tag时,又要把这个子tag想象成一个个新的XML,将其视为一个新的JavaBean,

并作为一个Field加入到父Bean当中,然后以此类推,通过循环的方式将整个XML进行解析。


所需JAR包:

  • commons-digester3-3.2.jar

  • commons-logging-1.0.4.jar

  • commons-beanutils-1.7.0.jar


作者:itmyhome

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值