JAVA之DocumentBuilder生成解析XML


1.创建DocumentBuilderFactory

DocumentBuilderFactory是用于创建DOM模式的解析器对象 , DocumentBuilderFactory是一个抽象工厂类,它提供了一个newInstance方法 ,这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。

/**
     * DOM模式的解析器对象
     * @return
     * @throws ParserConfigurationException
     */
    public static DocumentBuilder newDocumentBuilder() throws ParserConfigurationException {
        DocumentBuilderFactory documentBuilderFactory = DocumentBuilderFactory.newInstance();
        documentBuilderFactory.setFeature("http://apache.org/xml/features/disallow-doctype-decl", true);
        documentBuilderFactory.setFeature("http://xml.org/sax/features/external-general-entities", false);
        documentBuilderFactory.setFeature("http://xml.org/sax/features/external-parameter-entities", false);
        documentBuilderFactory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd", false);
        documentBuilderFactory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);
        documentBuilderFactory.setXIncludeAware(false);
        documentBuilderFactory.setExpandEntityReferences(false);
        
        // 调用工厂对象的newDocumentBuilder方法得到 DOM 解析器对象。
        return documentBuilderFactory.newDocumentBuilder();
    }

  

2.解析XML文件,代码里面都有注释

 public static void reader() throws ParserConfigurationException, SAXException, IOException {
        
        DocumentBuilder documentBuilder = XmlUtil.newDocumentBuilder();
        
        // InputStream is = new FileInputStream(new File("file.xml"));
        String strXML = "<CATALOG><CD><TITLE>Empire Burlesque</TITLE></CD><CD><TITLE>Hide your heart</TITLE></CD></CATALOG>";
        InputStream is = new ByteArrayInputStream(strXML.getBytes("UTF-8"));
        // 调用 DOM 解析器对象的 parse() 方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。
        Document document = documentBuilder.parse(is);
        // 得到 XML 文档的根节点
        Element rootElement = document.getDocumentElement();
        rootElement.normalize();
        
        // 得到节点的子节点
        NodeList catalogs = rootElement.getChildNodes();
        if (catalogs != null) {
            for (int i = 0; i < catalogs.getLength(); i++) {
                Node cd = catalogs.item(i);
                // TEXT_NODE 说明该节点是文本节点
                // ELEMENT_NODE 说明该节点是个元素节点
                if (cd.getNodeType() == Node.ELEMENT_NODE) {
                    // 取得节点的属性值
                    // String email = user.getAttributes().getNamedItem("attr").getNodeValue();
                    // 轮循子节点
                    for (Node node = cd.getFirstChild(); node != null; node = node.getNextSibling()) {
                        if (node.getNodeType() == Node.ELEMENT_NODE) {
                            if (node.getNodeName().equals("TITLE")) {
                                Node titleNode = node.getFirstChild();
                                // 如果是文本
                                if (titleNode.getNodeType() == Node.TEXT_NODE) {
                                    
                                    System.out.println("节点的值:" + titleNode.getNodeValue());
                                }
                                
                            }
                            
                        }
                    }
                }
            }
        }
        
    }

  

3.创建XML

public static void writer() throws ParserConfigurationException, TransformerException {
        Map<String, String> maps = new HashMap<String, String>(16);
        maps.put("ARTIST", "Bonnie Tyler");
        maps.put("TITLE", "Hide your heart");
        maps.put("COUNTRY", "UK");
        Document document = XmlUtil.newDocument();
        // 根节点
        Element rootEmement = document.createElement("CATALOGS");
        document.appendChild(rootEmement);
        
        Element cdElement = document.createElement("CD");
        rootEmement.appendChild(cdElement);
        
        for (String key : maps.keySet()) {
            Element field = document.createElement(key);
            field.appendChild(document.createTextNode(maps.get(key)));
            cdElement.appendChild(field);
        }
        
        // 设置XML声明中standalone为yes,即没有dtd和schema作为该XML的说明文档,且不显示该属性
        document.setXmlStandalone(true);
        
        // 开始生成XML文件
        TransformerFactory tf = TransformerFactory.newInstance();
        Transformer transformer = tf.newTransformer();
        DOMSource source = new DOMSource(document);
        transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
        transformer.setOutputProperty(OutputKeys.INDENT, "yes");
        StringWriter writer = new StringWriter();
        StreamResult result = new StreamResult(writer);
        // 生成到文件里
        // StreamResult result = new StreamResult("D:\\cds.xml");
        transformer.transform(source, result);
        String output = writer.getBuffer().toString(); // .replaceAll("\n|\r", "");
        try {
            writer.close();
        }
        catch (Exception ex) {
        }
        System.out.println(output);
    }

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM