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出现了...