最近在做的项目内容是接入多个第三方接口,有些第三方接口做的比较早,数据的传输还是xml格式,自然需要对xml文件进行读写,这篇博客准备总结一下xml文件读写相关的内容,语言依旧是java。
对于任何一个文件,都有编码格式,xml文件也不例外;而对于任何一个第三方插件,也会有版本号,xml文件同样也存在。所以,xml文件第一行一般都是这个样子"<?xml version="1.0" encoding="UTF-8"?>"
交代完了共性,下面就是xml文件本身的内容了。xml文件类似多叉树,有且只有一个根节点,每个节点有自己的属性和子节点。
对于一款插件来说,自然要提供对以上元素的CRUD(增删改查)操作,对于每一个操作,可能需要提供多种方式来完成相应的需求。
这篇博客,想实现基础的功能,一些复杂的功能,会在另外一篇博客进行介绍。
想实现以下一些功能:
1.能够读写项目的某个xml文件
2.能够获取某个节点,进行CURD操作
3.能够获取节点的某个属性,进行CURD操作
以下是一个xml文件,使用dom4j进行解析
<?xml version="1.0" encoding="UTF-8"?> <company name="名称"> <department id="1" name="武力部"> 攻城略地 <person name="常遇春">第一猛人</person> </department> <department id="2" name="行政部">忽悠人 <person name="朱元璋">大boss</person> </department> </company>
package dom4j;
import java.io.File;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
/**
*
* explaintion dom4j简单使用
* 2016年7月4日 下午6:47:59
*/
public class ReadXml {
@SuppressWarnings("unchecked")
public static void main(String[] args) throws Exception {
//插件提供用于读写的类
SAXReader reader = new SAXReader();
//java io操作
File file = new File("source/company.xml");
//文档类
Document document = reader.read(file);
//根据一个文档对象获取根节点
Element root = document.getRootElement();
String name = root.getName();
//获取节点的名称
System.out.println("节点名称是:"+name);
//以下是对于节点属性的CURD
//获取节点指定属性名的值
String attrbuteValue = root.attributeValue("name");
System.out.println("节点属性名name的值:"+attrbuteValue);
//增加节点的属性
root.addAttribute("year", "1");
Attribute attribute = root.attribute("year");
//删除节点的属性,只能通过这种方式删除,Attribute需要通过节点以及属性名称拿到
root.remove(attribute);
//获取节点的文本内容
String textValue = root.getTextTrim();
System.out.println("节点的文本内容:"+textValue);
//返回子节点中第一个名为department的节点
Element element = root.element("department");
System.out.println(element.attributeValue("name"));
//对于节点的所有子节点,可以进行如下遍历
List<Element> elements = root.elements("department");
for(Element el:elements){
System.out.println(el.attributeValue("name"));
}
//删除某个节点
root.remove(element);
}