DOM4J操作XML(包括封装和解析)

先来看看dom4j中相应XML的DOM树建立的继承关系

针对于XML标准定义。相应于图2-1列出的内容,dom4j提供了下面实现:

以下给出一个详细事例:

package com.iboxpay.settlement.gateway.common.util;



import java.io.IOException;

import java.io.StringReader;

import java.io.StringWriter;



import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

import org.dom4j.io.OutputFormat;

import org.dom4j.io.SAXReader;

import org.dom4j.io.XMLWriter;



import com.iboxpay.settlement.gateway.ccb.Constant;

import com.iboxpay.settlement.gateway.common.exception.PackMessageException;

import com.iboxpay.settlement.gateway.common.exception.ParseMessageException;



/**

 * DOM4j工具类

 * @author caolipeng

 */

public class DomUtil {

    /**

     * 加入孩子节点元素

     * @param parent 父节点

     * @param childName 孩子节点名称

     * @param childValue 孩子节点值

     * @return 新增节点

     */

    public static Element addChild(Element parent, String childName,

            String childValue) {

        Element child = parent.addElement(childName);//加入节点元素

        child.setText(childValue == null ?

"" : childValue); //为元素设值

        return child;

    }

    /**

     * DOM4j的Document对象转为XML报文串

     * @param document

     * @param charset

     * @return 经过解析后的xml字符串

     */

    public static String documentToString(Document document,String charset) {

        StringWriter stringWriter = new StringWriter();

        OutputFormat format = OutputFormat.createPrettyPrint();//获得格式化输出流  

        format.setEncoding(charset);//设置字符集,默觉得UTF-8

        XMLWriter xmlWriter = new XMLWriter(stringWriter, format);//写文件流

        try {

            xmlWriter.write(document);

            xmlWriter.flush();

            xmlWriter.close();

        } catch (IOException e) {

            throw new RuntimeException(e);

        }

        return stringWriter.toString();

    }

    /**

     * 去掉声明头的(即<?xml...?>去掉)

     * @param document

     * @param charset

     * @return

     */

    public static String documentToStringNoDeclaredHeader(Document document,String charset) {

        String xml = documentToString(document, charset);

        return xml.replaceFirst("\\s*<[^<>]+>\\s*", "");

    }

    /**

     * 解析XML为Document对象

     * @param xml 被解析的XMl

     * @return Document

     * @throws ParseMessageException

     */

    public final static Element parseXml(String xml)throws ParseMessageException{

        StringReader sr = new StringReader(xml);

        SAXReader saxReader = new SAXReader();  

        Document document;

        try {

            document = saxReader.read(sr);

        } catch (DocumentException e) {

            throw new ParseMessageException(e);

        }

        Element rootElement = document.getRootElement();    

        return rootElement;

    }

    

    public final static String getText(Element e, String tag){

        Element _e = e.element(tag);

        if(_e != null)

            return _e.getText();

        else

            return null;

    }

    public final static String getTextTrim(Element e, String tag){

        Element _e = e.element(tag);

        if(_e != null)

            return _e.getTextTrim();

        else

            return null;

    }

    /**

     * 获取节点值.节点必须不能为空,否则抛错

     * @param parent

     * @param tag

     * @return

     * @throws ParseMessageException

     */

    public final static String getTextTrimNotNull(Element parent, String tag) throws ParseMessageException{

        Element e = parent.element(tag);

        if(e == null)

            throw new ParseMessageException(parent.getName() + " -> " + tag + " 节点为空.");


        else

            return e.getTextTrim();

    }

    /**

     * 节点必须不能为空,否则抛错

     * @param parent

     * @param tag

     * @return

     * @throws ParseMessageException

     */

    public final static Element elementNotNull(Element parent, String tag) throws ParseMessageException{

        Element e = parent.element(tag);

        if(e == null)

            throw new ParseMessageException(parent.getName() + " -> " + tag + " 节点为空.");


        else

            return e;

    }

    public static void main(String[] args) throws PackMessageException, ParseMessageException {

        Document document = DocumentHelper.createDocument();  

        document.setXMLEncoding("GB2312");

        Element root = document.addElement("TX");

        DomUtil.addChild(root, "REQUEST_SN", "bankBatchSeqId");

        DomUtil.addChild(root, "CUST_ID", "cust_id");

        DomUtil.addChild(root, "USER_ID", "user_id");

        DomUtil.addChild(root, "PASSWORD", "password");

        DomUtil.addChild(root, "TX_CODE", "txCode");

        DomUtil.addChild(root, "LANGUAGE", "CN");

        Element tx_info = root.addElement(Constant.TX_INFO);

        DomUtil.addChild(tx_info, Constant.REQUEST_SN1, "request_sn1");

        String xml = DomUtil.documentToStringNoDeclaredHeader(root.getDocument(), "GBK");

        System.out.println(xml);

        root = parseXml(xml);

        System.out.println(root.element("TX_INFO").elementText("REQUEST_SN1"));

    }

}

主函数測试结果为:

<TX>

  <REQUEST_SN>bankBatchSeqId</REQUEST_SN>

  <CUST_ID>cust_id</CUST_ID>

  <USER_ID>user_id</USER_ID>

  <PASSWORD>password</PASSWORD>

  <TX_CODE>txCode</TX_CODE>

  <LANGUAGE>CN</LANGUAGE>

  <TX_INFO>

    <REQUEST_SN1>request_sn1</REQUEST_SN1>

  </TX_INFO>

</TX>



request_sn1




博客參考文献:http://www.cnblogs.com/macula/archive/2011/07/27/2118003.html


DOM4J操作XML(包括封装和解析)的更多相关文章

  1. xml解析 使用dom4j操作xml

     使用dom4j操作xml 1 导入 dom4j,的jar包   2 指定要解析的XML文件 SAXReader sr=new SAXReader(); Document document= sr.r ...

  2. 2.3 使用 dom4j 对 xml文件进行 dom 解析

    // 使用dom4j对XML文档进行解析 CRUD public class Demo1 { //读取XML文档中第二本书的书名 <书名>javaWEB</书名> @Test ...

  3. Java xml 操作(Dom4J修改xml   + xPath技术  + SAX解析 + XML约束)

    1 XML基础 1)XML的作用 1.1 作为软件配置文件 1.2 作为小型的"数据库" 2)XML语法(由w3c组织规定的) 标签: 标签名不能以数字开头,中间不能有空格,区分大 ...

  4. XML学习笔记(2)--dom4j操作XML

    1. 介绍(四种方式的比较这部分转载自:http://www.blogjava.net/xcp/archive/2010/02/12/312617.html) 1)DOM(JAXP Crimson解析 ...

  5. 使用dom4j操作XML

    DOM4J介绍 DOM4J是使用Java语言编写的,用于读写及操作XML的一套组件,DOM4J同时具有DOM修改文件的优点和SAX读取快速的优点. DOM4J的使用 首先下载dom4j的JAR包,我用 ...

  6. dom4j操作xml文档

    java Dom4j解析XML文件 标签(空格分隔):java进阶 xml文档: <?xml version="1.0" encoding="UTF-8" ...

  7. Strus2第一次课:dom4j操作xml

    先从底层的xml操作技术记录: 当我们新建一个项目,什么架包都没加入的时候,java提供了 org.w3c.dom给我们操作xml里面的元素 import org.w3c.dom.Document; ...

  8. dom4j操作xml对象

         // 获取Documen对象      public static Document getDocument(String path) throws Exception{           ...

  9. 使用Dom4j操作XML数据

    --------------siwuxie095                             dom4j 是一个非常优秀的 Java XML 的 API, 用来读写 XML 文件 和操作 ...

随机推荐

  1. [Java基础] 使用JMAP dump及分析dump文件

    转载:http://blog.csdn.net/kevin_luan/article/details/8447896 http://liulinxia02.blog.163.com/blog/stat ...

  2. 如何看待Linux操作系统的用户空间和内核空间

    作为中央核心处理单元的CPU,除了生产工艺的不断革新进步外,在处理数据和响应速度方面也需要有权衡.稍有微机原理基础的人都知道Intel X86体系的CPU提供了四种特权模式ring0~ring3,其中 ...

  3. FL2440 ubifs文件系统烧录遇到的问题——内核分区的重要性

    之前用的文件系统是initramfs的,这种文件系统是编译进内核里的,而开机之后内核是写在内存中的,所以每次掉电之后写进文件系统中的东西都会丢失.所以决定换成ubifs的文件系统.这种文件系统是跟内核 ...

  4. 【Cocos2d-x 3.0 基础系列一】 各类回调函数写法汇总

    一.button回调 1. Lambda 表达式,C++11 Lambda 赋予了Cocos2d-x 3.0创建回调函数的灵活性. auto itemNor = Sprite::create(&quo ...

  5. Hadoop之Sqoop详解

    sqoop数据迁移1.简介 sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具. 导入数据:MySQL,Oracle导入数据到Hadoop的HDFS.HIVE.HBA ...

  6. BUPT复试专题—解析表达式(2015)

    题目描述 输入一个字符串形式的表达式,该表达式中包括整数,四则运算符(+.-.*./),括号,三角函数(sin(x).cos(x).tan(x)),底数函数(lg(x).ln(x)),计算该表达式的值 ...

  7. ffmpeg 复用

    aa 将mkv中的音视频复用成ts流: ffmpeg -i 32_mkv_h264_718x480_ac3.mkv  -codec copy -bsf:v h264_mp4toannexb  -f m ...

  8. 【Java】Java_02环境配置

    JDK是什么?JRE是什么?JDK和JRE的区别? Java Runtime Environment (JRE) 包含: Java虚拟机.库函数.运行Java应用程序和Applet所必须文件 Java ...

  9. JPA学习笔记1——JPA基础 (转自CSDN)

    http://blog.csdn.net/chjttony/article/details/6086298 1.JPA简介: Java持久化规范,是从EJB2.x以前的实体Bean(Entity be ...

  10. 轻松学习JavaScript十四:JavaScript的RegExp对象(正則表達式)

    一RegExp对象概述 RegExp对象表示正則表達式,RegExp是正則表達式的缩写.它是对字符串运行模式匹配的强大工具. RegExp 对象用于规定在文本中检索的内容. 当您检索某个文本时.能够使 ...