`
bask
  • 浏览: 146695 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

DOM XML解析 删除

XML 
阅读更多
import java.util.HashMap;
import java.util.Map;

/**
 * 属性值类,描述页面动态表单域信息
 *
 * 
 */
public class AttributeVO implements java.io.Serializable {
    private static final long serialVersionUID = -8683922528577545017L;
    public static enum Sort {
        ASC, DESC
    }

    /**
     * id
     */
    private String id;
    /**
     * 字段名
     */
    private String name;
    /**
     * 控件类型
     */
    private String type;
    /**
     * 描述
     */
    private String description;
    /**
     * 默认值
     */
    private String value;
    /**
     * 码表Code
     */
    private String codeId;
    /**
     * 正则
     */
    private String regex;
    /**
     * 排序
     */
    private String order;

    /**
     * Select下拉数据
     */
    private Map<String, String> select = new HashMap<String, String>();

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public String getValue() {
        return value;
    }

    public void setValue(String value) {
        this.value = value;
    }

    public String getCodeId() {
        return codeId;
    }

    public void setCodeId(String codeId) {
        this.codeId = codeId;
    }

    public String getRegex() {
        return regex;
    }

    public void setRegex(String regex) {
        this.regex = regex;
    }

    public String getOrder() {
        return order;
    }

    public void setOrder(String order) {
        this.order = order;
    }

    public Map<String, String> getSelect() {
        return select;
    }

    public void setSelect(Map<String, String> select) {
        this.select = select;
    }
}


import org.springframework.util.ResourceUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;
import java.io.*;
import java.util.*;

/**
 * Date: 2010-4-4
 * Time: 22:39:55
 */
public class AttributeVOXMLUtil {

    public static Map<String, Map<String, AttributeVO>> attributeMap = new HashMap<String, Map<String, AttributeVO>>();

    /**
     * 解析XML
     *
     * @param xmlName
     * @return
     * 
     */
    private static Document getDocument(String xmlName) {
        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
        DocumentBuilder db = null;
        try {
            db = dbf.newDocumentBuilder();
        } catch (ParserConfigurationException e) {
            e.printStackTrace();
        }
        Document document = null;
        try {
            document = db.parse(new FileInputStream(ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX + xmlName)));
        } catch (IOException e) {
            throw new XMLParserException("XML文件没有找到", e);
        } catch (SAXException e) {
            throw new XMLParserException("XML解析错误");
        }
        return document;
    }

    /**
     * 根据Path返回节点列表
     *
     * @param document
     * @param xPath
     * @return
     * 
     */
    private static NodeList getNodeList(Document document, String xPath) {
        XPathFactory xpathFactory = XPathFactory.newInstance();
        XPath xpath = xpathFactory.newXPath();
        NodeList nodeList = null;
        try {
            nodeList = (NodeList) xpath.evaluate(xPath, document, XPathConstants.NODESET);
        } catch (XPathExpressionException e) {
            throw new XMLParserException("XPath错误");
        }
        return nodeList;
    }

    /**
     * 根据Path返回单个节点
     *
     * @param document
     * @param xPath
     * @return
     * 
     */
    private static Node getNode(Document document, String xPath) {
        XPathFactory xpathFactory = XPathFactory.newInstance();
        XPath xpath = xpathFactory.newXPath();
        Node node = null;
        try {
            node = (Node) xpath.evaluate(xPath, document, XPathConstants.NODE);
        } catch (XPathExpressionException e) {
            throw new XMLParserException("XPath错误");
        }
        return node;
    }

    /**
     * 根据id删除节点
     *
     * @param xmlName
     * @param itemId
     */
    private static void removeNode(String xmlName, String itemId) {
        Document document = getDocument(xmlName);
        Element root, attributeItem;
        root = document.getDocumentElement();
        attributeItem = (Element) getNode(document, "//attributeItem[@id='" + itemId + "']");
        if (attributeItem != null) {
            //删除一个节点
            root.removeChild(attributeItem);
            //写入到xml
            writeXml(document, xmlName);
            //删除缓存中的Map
            attributeMap.remove(itemId);
        }
    }

    /**
     * 写入XML
     *
     * @param doc
     * @param xmlName
     */
    private static void writeXml(Document doc, String xmlName) {
        OutputStream fileoutputStream = null;
        try {
            fileoutputStream = new FileOutputStream(ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX + xmlName));
            TransformerFactory factory = TransformerFactory.newInstance();
            Transformer transformer = factory.newTransformer();
            DOMSource source = new DOMSource(doc);
            StreamResult result = new StreamResult(fileoutputStream);
            transformer.transform(source, result);
        } catch (FileNotFoundException e) {
            throw new XMLParserException("没有找到XML文件", e);
        } catch (TransformerConfigurationException e) {
            throw new XMLParserException("文件写入错误", e);
        } catch (TransformerException e) {
            throw new XMLParserException("文件写入错误", e);
        } finally {
            if (fileoutputStream != null)
                try {
                    fileoutputStream.close();
                } catch (IOException e) {
                    throw new XMLParserException("文件流错误");
                }
        }
    }

    /**
     * 返回信息
     *
     * @param xmlName
     * @return
     * 
     */
    public static Map<String, Map<String, AttributeVO>> queryParserXml(String xmlName) {
        Document document = getDocument(xmlName);
        document.normalize();
        NodeList attributeItemList = getNodeList(document, "//attributeItem");
        int itemLen = attributeItemList.getLength();
        for (int i = 0; i < itemLen; i++) {
            Element element = (Element) attributeItemList.item(i);
            attributeMap.put(element.getAttribute("id"), getAttributeVOMap(document, "//attributeItem[@id='" + element.getAttribute("id") + "']/attribute"));
        }
        return attributeMap;
    }

    /**
     * 封装AttributeItem信息
     *
     * @param document
     * @param xPath
     * @return
     * 
     */
    private static Map<String, AttributeVO> getAttributeVOMap(Document document, String xPath) {
        Map<String, AttributeVO> attributeVOMap = new HashMap<String, AttributeVO>();
        NodeList attributeItemList = getNodeList(document, xPath);
        int itemLen = attributeItemList.getLength();
        for (int i = 0; i < itemLen; i++) {
            Element element = (Element) attributeItemList.item(i);
            attributeVOMap.put(element.getAttribute("name"), getAttributeVO(element, document, xPath + "[@id='" + element.getAttribute("id") + "']/select"));
        }
        return attributeVOMap;
    }

    /**
     * 返回AttributeVO信息
     *
     * @param element
     * @param document
     * @param xPath
     * @return
     * 
     */
    private static AttributeVO getAttributeVO(Element element, Document document, String xPath) {
        Map<String, String> selectMap = new HashMap<String, String>();
        AttributeVO attributeVO = new AttributeVO();
        NodeList attributeItemList = getNodeList(document, xPath);
        int itemLen = attributeItemList.getLength();
        for (int i = 0; i < itemLen; i++) {
            Element selectElement = (Element) attributeItemList.item(i);
            selectMap.put(selectElement.getAttribute("id"), selectElement.getAttribute("value"));
        }
        attributeVO.setId(element.getAttribute("id"));
        attributeVO.setName(element.getAttribute("name"));
        attributeVO.setType(element.getAttribute("type"));
        attributeVO.setDescription(element.getAttribute("description"));
        attributeVO.setValue(element.getAttribute("value"));
        attributeVO.setCodeId(element.getAttribute("codeId"));
        attributeVO.setRegex(element.getAttribute("regex"));
        attributeVO.setOrder(element.getAttribute("order"));
        attributeVO.setSelect(selectMap);
        return attributeVO;
    }

    /**
     * 返回AttributeVO列表
     *
     * @param itemId
     * @return
     * 
     * @see
     */
    public static List<AttributeVO> queryAttribute(final String itemId) {
        return queryAttribute(itemId, AttributeVO.Sort.ASC);
    }

    /**
     * 返回AttributeVO列表
     *
     * @param itemId
     * @param sort
     * @return
     * 
     * @see
     */
    public static List<AttributeVO> queryAttribute(final String itemId, final AttributeVO.Sort sort) {
        final List<AttributeVO> attributeVOList = new LinkedList<AttributeVO>();
        final Map<String, AttributeVO> attributeVOMap = attributeMap.get(itemId);
        if (attributeVOMap != null) {
            final Iterator<String> iterName = attributeVOMap.keySet().iterator();
            while (iterName.hasNext()) {
                attributeVOList.add(attributeVOMap.get(iterName.next()));
            }
            //排序
            Collections.sort(attributeVOList, new Comparator<AttributeVO>() {
                @Override
                public int compare(AttributeVO o1, AttributeVO o2) {
                    final AttributeVO AttributeVO1 = o1;
                    final AttributeVO AttributeVO2 = o2;
                    final Integer order1 = Integer.valueOf(AttributeVO1.getOrder());
                    final Integer order2 = Integer.valueOf(AttributeVO2.getOrder());
                    if (sort.equals(AttributeVO.Sort.ASC))
                        return order1 < order2 ? 0 : 1;
                    else
                        return order1 < order2 ? 1 : 0;
                }
            });
        }
        return attributeVOList;
    }

    /**
     * 根据itemId删除元素
     *
     * @param itemId
     */
    public static void removeItem(String itemId) {
        removeNode("attribute.xml", itemId);
    }
}
分享到:
评论

相关推荐

    DOMParser解析xml

    DOMParser接口提供了解析XML字符串并创建DOM文档的方法,以便于开发者可以使用DOM API来查询、修改或操作XML数据。 以下是对"DOMParser解析XML"这一主题的详细说明: 1. **DOMParser的基本使用**: 使用DOMParser...

    XML解析之DOM

    在"XML解析之DOM"这一主题中,我们将深入探讨DOM解析器如何工作,以及如何通过DOM API获取XML文件中的信息。DOM解析器将整个XML文档加载到内存中,形成一个节点树,每个元素、属性、文本等内容都对应一个节点。这种...

    java_dom解析xml xml java

    ### Java DOM 解析 XML 在Java中,DOM(Document Object Model)是一种用于处理XML文档的标准接口。通过DOM,我们可以将整个XML文档加载到内存中,并对其进行读取、修改等操作。这种方式非常适合那些需要对XML文档...

    dom4j---xml解析jar包

    **DOM4J——XML解析库详解** XML(eXtensible Markup Language)作为一种标记语言,广泛应用于数据交换、配置文件和文档存储等领域。在Java环境中,解析XML文档时,我们通常会遇到各种库,其中DOM4J是一个非常流行...

    DOM解析XML文件例子

    在这个例子中,我们将深入探讨如何使用DOM解析XML文件,以理解和掌握XML文档的结构,并进行数据提取、修改和创建。 首先,XML(Extensible Markup Language)是一种标记语言,用于存储和传输数据,具有自描述性和...

    DOM解析XML 创建XML

    DOM(Document Object Model)是处理XML文档的一种标准API,它将XML文档表示为一棵可操作的节点树,使得我们可以方便地对XML数据进行创建、查询、修改和删除。下面我们将深入探讨DOM解析XML以及如何创建XML。 DOM...

    dom4解析xml需要的包

    - `stax-x.x.x.jar`:STAX(Streaming API for XML)是一种流式XML解析API,允许程序逐个处理XML事件,提供了比SAX更高的灵活性和性能。 在实际项目中,为了使用DOM4J解析XML,需要将这些jar包加入到项目的类路径中...

    xmldom4j解析

    XML解析主要有两种方式:DOM(文档对象模型)和SAX(简单API for XML)。DOM解析会将整个XML文档加载到内存中形成一棵树形结构,方便访问任意节点,但内存消耗大;SAX解析则采用事件驱动,逐行读取XML,适合处理大型...

    易语言模块 XMLDOM 解析 构造 获取 更改 添加 删除 遍历元素 格式化XML

    换句话说:XML DOM 是用于获取、更改、添加或删除 XML 元素的标准。 模块简介: 1、XMLDOMDocument类: XML对象文档 -&gt;操作创建或读写(元素、节点、属性、注释)等 2、IXMLDOMNode类:每个元素或节点基本都会有的...

    DOM XML教程/DOM参考手册/DOM解析XML

    - 解析XML:如何使用DOM解析器加载XML文件,并将之转换为DOM树。 - 遍历和查询DOM:`getElementsByTagName()`, `getElementById()`, `getElementsByClassName()`等方法的使用。 - 操作DOM:添加、删除和修改节点,...

    android dom方式解析xml

    DOM解析器还允许我们修改现有节点的属性,添加或删除节点。例如,你可以用`setAttribute()`方法更改元素的属性,或者用`createElement()`创建新的元素节点,`appendChild()`将其添加到父节点。 在Android项目中,`...

    XMLDOM解析器

    3. **结点操作**:DOM解析器支持对XML节点的各种操作,如创建、删除、复制和移动。例如,创建一个新的元素并添加到文档中: ```csharp XmlElement newElement = doc.CreateElement("newElement"); doc....

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...

    dom4j解析XML所需jar包

    Jaxen可以与多种XML解析器(如DOM、DOM4J、JDOM等)协同工作,提供跨平台的XPath支持。 总结来说,DOM4J是一个全面且易用的XML处理工具,广泛应用于Java开发中。通过`dom4j-1.6.1.jar`和`jaxen-1.1.1.jar`这两个jar...

    dom4j解析xml文件的压缩包

    5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...

    C# XML解析方式

    - **简介**:DOM(Document Object Model)是另一种常用的XML解析技术,它将整个XML文档加载到内存中,并构建一个树状结构,允许程序对文档进行任意操作。 - **特点**: - **灵活性高**:可以任意访问和修改文档中的...

    Java使用sax、dom、dom4j解析xml文档

    在选择XML解析方式时,需要考虑文件大小、内存限制以及操作需求。SAX适合处理大文件并进行只读操作;DOM适用于需要快速查找和修改数据的场景,但需消耗更多内存;DOM4J则提供了更高级的功能和更友好的API,适合复杂...

Global site tag (gtag.js) - Google Analytics