dom4j解析XML的CURD操作

在开发JavaWeb项目中通常是利用XML配置文件来提高应用程序的访问效率,而在配置XML的同时,更多时候是对XML进行解析。

一、解析XML配置文件有两种机制:

DOM和SAX的机制:

DOM是将整个XML文件读到内容,形成一个倒状的树形结构。

SAX是一个一个的将XML文件中的元素加载的内存,不会形成一个倒状的树形结构。

常用dom4j的api: 主要使用到SAXReader类

SAXReader:表示DOM4J解析器

saxReader.read():加载需要解析的xml文件,返回document对象代表整个xml文件

document.getRootElement():取得根元素

element.getName():取得元素名称

rootElement.elements():取得该元素下的子元素的集合

element.element("车牌"):导航到"车牌"元素

element.getText():获取得某个元素的文本内容

element.elementText("产地"):导航到"产地"元素并获取该元素的文本内容

e.element("车牌").attributeValue("出产时间"):导航到"车牌"元素并获取该元素的“出产时间”属性的值

element.addElement("单价").setText("15");创建新元素并设置该元素的文本内容

二、在解析dom4j在XML配置文件的过程也需要使用到xpath技术

xpath技术:

在xml文件中快速定义符合xpath条件/路径的唯一/所有的元素

document.selectNodes(xpath);[取得所有的]

document.selectSingleNode(xpath);[取得单个的]

以下是dom4j解析XML文件的curd操作代码:

package cn.test.java.dom4j;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.io.Writer;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test;

public class XMLcurd {
    //创建document对象
    private Document getDocument() throws DocumentException {
        SAXReader saxReader = new SAXReader();
        Document document = saxReader.read(new File("src/cn/test/java/dom4j/test.xml"));
        return document;
    }
    //将document写入到指定的XML
    private void writerToXML(Document document)
    throws UnsupportedEncodingException, FileNotFoundException,
    IOException {
    //方法一:写入xml文件中包含有中文时
    //设置输出格式
    OutputFormat outputFormat = OutputFormat.createPrettyPrint();
    //设置输出编码方式
    outputFormat.setEncoding("UTF-8");
    //将内存中的字节流转换为字符流
    Writer writer = new OutputStreamWriter(new FileOutputStream("src/cn/test/java/dom4j/test.xml"),"UTF-8");
    //构造XMLWriter用于写入XML文件
    XMLWriter xmlWriter = new XMLWriter(writer,outputFormat);
    xmlWriter.write(document);
    xmlWriter.close();
}

    //XML的增加操作
    @Test
    public void Create() throws Exception{
        Document document = this.getDocument();
        Element rootElement = document.getRootElement();
        Element firstElement = (Element) rootElement.elements().get(0);
        firstElement.addElement("单价").setText("15");//在内存中(字节存储)
        writerToXML(document);
    }
    //XML的修改操作
    @Test
    public void upDate() throws Exception{
        Document document = this.getDocument();
        Element rootElement = document.getRootElement();
        Element secondElement = (Element) rootElement.elements().get(1);
        secondElement.element("产地").setText("深圳");
        writerToXML(document);

    }
    //XML的删除操作
    @Test
    public void delete() throws Exception{
        Document document = this.getDocument();
        Element rootElement = document.getRootElement();
        List<Element> elementList = rootElement.elements();
        for(Element e:elementList){
            Element bandElement = e.element("车牌");
            e.remove(bandElement);
        }
        writerToXML(document);
    }
}
时间: 2024-10-10 13:30:15

dom4j解析XML的CURD操作的相关文章

java中采用dom4j解析xml文件

一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4j解析xml的具体操作. 二.代码详情    dom4j是一个第三方开发组开发出的插件,所以在我们使用dom4jf的时候我们要去下载一下dom4j对应版本的jar导入在我们项目中.  1)xml文件: <?xml version="1.0" encoding="UTF-8&

【收藏用】--切勿转载JAVA 使用Dom4j 解析XML

原帖地址 : http://blog.csdn.NET/yyywyr/article/details/38359049 解析XML的方式有很多,本文介绍使用dom4j解析xml. 1.环境准备 (1)下载dom4j-1.6.1.jar (2)下载junit-4.10.jar 2.温馨提示 解析XML过程是通过获取Document对象,然后继续获取各个节点以及属性等操作,因此获取Document对象是第一步,大体说来,有三种方式: (1)自己创建Document对象   Document docu

转:在java中使用dom4j解析xml

在java中使用dom4j解析xml 虽然Java中已经有了Dom和Sax这两种标准解析方式 但其操作起来并不轻松,对于我这么一个初学者来说,其中部分代码是活生生的恶心 为此,伟大的第三方开发组开发出了Jdom和Dom4j等工具 鉴于目前的趋势,我们这里来讲讲Dom4j的基本用法,不涉及递归等复杂操作 Dom4j的用法很多,官网上的示例有那么点儿晦涩,这里就不写了 首先我们需要出创建一个xml文档,然后才能对其解析 xml文档: <?xml version="1.0" encod

java dom4j解析xml实例(2)

java利用dom4j解析xml 需要的jar包: dom4j官方网站在 http://www.dom4j.org/ 下载dom4j-1.6.1.zip 解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要加入包jaxen-1.1-beta-7.jar(如果不导入这个架包程序可以执行出结果,但最后会报异常) 将相关jar包引入后,实际解析操作如下:  1.要解析的xml文件province.xml: <china dn="d

使用dom4j解析XML文档

dom4j的包开源包,不属于JDK里面,在myeclipse中要单独导入在项目中,这里不累赘了 做这个过程,很慢,因为很多方法没用过不熟悉,自己得去查帮助文档,而且还得去试,因为没有中文版,英文翻译不准确,也会导致多个同名的方法理解和用法不同 XML: <?xml version="1.0" encoding="utf-8"?> <students> <student age="25"> <name>

javaweb dom4j解析xml文档

1.什么是dom4j dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的软件,可以在SourceForge上找到它.在IBM developerWorks上面还可以找到一篇文章,对主流的Java XML API进行的性能.功能和易用性的评测,所以可以知道dom4j无论在哪个方面都是非常出色的.如今可以看到越

XML学习笔记(五):使用 jdom和dom4j 解析XML

XML解析的详细分析与jaxp解析XML详见:XML学习笔记(四):使用 DOM和SAX 解析XML 一.JDom 1.创建XML文件: 1)Document类即代表整个XML文档,把生成的 Document 利用 XMLOutputter 类输出即可. 2)映射关系:元素:Element:属性:Attribute:注解:Comment:文本信息:Text: 3)注意:addContent()是追加,setContent()会覆盖. /** * 创建XML * * @throws IOExcep

在java项目中怎样利用Dom4j解析XML文件获取数据

在曾经的学习.net时常常会遇到利用配置文件来解决项目中一些须要常常变换的数据.比方数据库的连接字符串儿等.这个时候在读取配置文件的时候.我们一般会用到一个雷configuration,通过这个类来进行直接读取,能够说这是程序中直接封装好的,包含配置文件里书写的格式等等.那么,假设.想要在配置文件里写一些其它的数据,直接以XML文件的格式进行书写.这个时候在后台怎样读取XML文件里的数据呢?这里利用Dom4j来解析XML文件里连接oracle数据库的xml数据. 在使用之前,首先要在自己的项目中

【学习笔记】关于DOM4J:使用DOM4J解析XML文档

一.概述 DOM4J是一个易用的.开源的库,用于XML.XPath和XSLT中.采用了Java集合框架并完全支持DOM.SAX.和JAXP. DOM4J最大的特色是使用大量的接口,主要接口都在org.dom4j这个包里定义: 二.DOM4J的接口 Attribute:定义了XML的属性: Branch:是能够包含子节点的节点,如XML元素(Element)和文档(Documents)定义了一个公共的行为: CDATA:定义了XML的CDATA区域: CharacterData:是一个标识接口,标