java解析XML

XMl (eXtensible Markup Language)可扩展标记语言 属于数据存储语言
XML的特色:
能够在任何应用程序中读取数据
极其简单
简化数据共享和数据传输
XML和HTML的区别:HTML 旨在显示信息,而 XML 旨在传输信息。XML要求全部的标记都要成双成对出现,并区分大小写,而HTML标记不区分大小写,java

(DOM解析方式)
mysql

须要在工程中导入dom4j.jar包
dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具备性能优异、功能强大和极其易使用的特色,
连接:https://pan.baidu.com/s/1c2pTmd6 密码:u6oysql

org.dom4j.io提供了两个类:SAXReader和DOMReader,前者从一个现有的w3c DOM树构建dom4j树,而SAXReader则使用SAX解析器,从不一样的输入源构建dom4j树。数据库

SAXReader方式:
解析步骤:dom

1):建立SAXReader对象(须要导包org.dom4j.io.SAXReader)
SAXReader reader = new SAXReader();
2):读取整个XML文件结构(须要包:org.dom4j.Element;)
Document doc = reader.read(File file);
read()方法能够给一个文件路径 也能够给一个File的对象
3)获取XML文件的根节点  (须要包:org.dom4j.Element)
Element root = doc.getRootElement();
4)获取节点下的元素
List<Element> childList  =root.elements();
获取当前元素指定名称的子元素
root.element(String name)
获取当前元素的名称
root.getName()
获取当前元素的内容
root.getText()
root.getTextTrim()
获取当前元素下指定名称的子元素内容
root.elementText(String name)
获取当前元素的值
root.getStringValue();

所有代码以下:sqlserver

 

import java.io.File;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class SAXReaderDemo {

    public static void main(String[] args) {
        try {

            // 建立SAXReader对象
            SAXReader reader = new SAXReader();
            // 读取XML文件结构
            Document doc = reader.read(new File("config/server.xml"));
            // 获取XML文件根节点
            Element root = doc.getRootElement();
            // 获取根节点一下的子元素
            List<Element> list = root.elements();

            for (Element item : list) {

                if ("MySql".equals(item.getName())) {
                    System.out.println("MySQL数据库");
                    // 获取MySql下的子元素
                    List<Element> list1 = item.elements();
                    // 迭代子节点的元素值
                    for (Element element : list1) {

                        System.out.println("当前元素是:" + element.getName() + "值是:"
                                + element.getStringValue());
                    }
                } else if ("SQLServer".equals(item.getName())) {
                    System.out.println("SQLServer数据库");
                    // 获取SQLServer下的子元素
                    List<Element> list1 = item.elements();
                    // 迭代子节点的元素值
                    for (Element element : list1) {

                        System.out.println("当前元素是:" + element.getName() + "值是:"
                                + element.getStringValue());
                    }

                }

            }

        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    
}

 

 

 

个人项目结构以下:性能

 

 xml文件以下:url

<?xml version = "1.0" encoding="UTF-8"?>
<server>
    <MySql>
        <driver>com.mysql.jdbc.Driver</driver>
        <url>jdbc:mysql://localhost:3306/database?useSSL=true</url>
        <user>root</user>
        <pwd>1234</pwd>
    </MySql>
    <SQLServer>
        <driver>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver>
        <url>jdbc:sqlserver://localhost:1433;DatabaseName=database</url>
        <user>sa</user>
        <pwd>1234</pwd>
    </SQLServer>
</server>

用java生成xml文件spa

1)建立Document对象 经过DocumentHelper的createdocument()方法来获取document对象(须要导包:org.dom4j.Document;org.dom4j.DocumentHelper) Document doc = DocumentHelper.createDocument(); 2)建立根节点 注意 XML文件的根节点只能有一个(须要导包:org.dom4j.Element) Element root = doc.addElement(String name); 3)添加子节点 返回的是当前节点对象 Element child = root.addElement(String name); 4)后面能够继续添加节点 也能够添加子节点下的子节点 child.addElement(String name); 添加节点 child.addText(String name); 添加节点中的内容 完善DOM结构后 就能够把Document对象写入xml文件中 1)建立XMLWriter 流对象 XMLWriter writer=new XMLWriter(); 2)为XMLWriter设定低级输出流 FileOutputStream fos=new FileOutputStream("config/new.xml"); writer.setOutputStream(fos); 3)将document对象写入xml文件中 writer.write(doc); 4)最后关闭XMLWriter流对象 writer.close();

具体代码以下:code

 

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;

import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.XMLWriter;


public class createXML {
    public static void main(String[] args) {
        
        //建立document对象
        Document doc = DocumentHelper.createDocument();
        //建立根节点
        Element root = doc.addElement("server");
        //在根节点上建立两个子节点
        Element child1 = root.addElement("MySql");
        Element child2 = root.addElement("SQLServer");
        
        
        //建立第一个子节点下的节点
        Element child1_driver = child1.addElement("driver");
        child1_driver.addText("com.mysql.jdbc.Driver");
        
        Element child1_url = child1.addElement("url");
        child1_url.addText("jdbc:mysql://localhost:3306/database?useSSL=true");
        
        Element child1_user = child1.addElement("user");
        child1_user.addText("root");
        
        Element child1_pwd = child1.addElement("pwd");
        child1_pwd.addText("1234");
        
        //建立第二个子节点下的节点
        Element child2_driver = child2.addElement("driver");
        child2_driver.addText("com.microsoft.sqlserver.jdbc.SQLServerDriver");
        
        Element child2_url = child2.addElement("url");
        child2_url.addText("jdbc:sqlserver://localhost:1433;DatabaseName=database");
        
        Element child2_user = child2.addElement("user");
        child2_user.addText("sa");
        
        Element child2_pwd = child2.addElement("pwd");
        child2_pwd.addText("1234");
        
        try {
            //建立XMLWriter 流对象
            XMLWriter writer=new XMLWriter();
            //注:XMLWriter writer=new XMLWriter(OutputStream os);,可省略第二步
            //为XMLWriter设定低级输出流
            FileOutputStream fos=new FileOutputStream("config/new.xml");
            writer.setOutputStream(fos);
            //将document对象写入xml文件中
            writer.write(doc);
            //最后关闭XMLWriter流对象
            writer.close();
            
        } catch (Exception e) {
            
            e.printStackTrace();
        } 
    }

}

 

运行代码后刷新config  发现new.xml出现了...

相关文章
相关标签/搜索