import java.io.File;
import java.io.FileWriter;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class Dom4jDemo {
public boolean createXML(String fileName){
boolean isOk= false;
//建立document对象
Document doc= DocumentHelper.createDocument();
//建立XML文档的根books
Element students= doc.addElement("students");
students.addComment("This is a test for dom4j");//加入一行注释
/**加入第一个student节点*/
Element student= students.addElement("student");//加入第一个student节点
student.addAttribute("value","god");//加入value属性和值
Element name= student.addElement("name");//加入name节点
name.setText("finina");//为name设置值
Element age=student.addElement("age");//加入age节点
age.setText("25");//为age设置值
Element sex=student.addElement("sex");//加入sex节点
sex.setText("male");//为sex设置值
/**加入第二个student节点*/
student= students.addElement("student");
student.addAttribute("value","cat");
name= student.addElement("name");
name.setText("fly");
age=student.addElement("age");
age.setText("17");
sex=student.addElement("sex");
sex.setText("female");
/**加入team节点*/
Element team=students.addElement("team");
team.addText("05093A");
/**
*将doc中的内容写入xml文件中
**/
try{
OutputFormat format= OutputFormat.createPrettyPrint();//设置格式
format.setEncoding("GBK");//必要,否则无法解析中文
//输出为文件
XMLWriter writer= new XMLWriter(new FileWriter(fileName),format);
writer.write(doc);
writer.flush();
//
isOk= true;
}catch(Exception e){
e.printStackTrace();
}
return isOk;
}
public boolean modifigXML(String oldFileName,String newFileName){
boolean isOk= false;
try{
SAXReader reader= new SAXReader();//创建SAX阅读器
Document doc= reader.read(new File(oldFileName));//将所有文件内容读取生存Document对象
/**修改内容之一: 如果student节点中value属性的内容为god,则修改成king
*因为做人不能太嚣张
*/
List list= doc.selectNodes("/students/student/@value");//搜索出所有位于students节点下的student节点中的value属性位置放入集合中
Iterator iter= list.iterator();//加载迭代器
//迭代集合
while(iter.hasNext()){
Attribute attr= (Attribute)iter.next();
if(attr.getValue().equals("god"))//比对值是否相等
attr.setValue("king");//设置值
}
list= doc.selectNodes("/students/team");//搜索出所有位于students节点下team节点位置放入集合中
iter= list.iterator();//加载迭代器
//迭代集合
if(iter.hasNext()){
Element team= (Element)iter.next();
team.setText("05084A");//设置值
Element teacher= team.addElement("teacher");//添加节点
teacher.setText("godfather");//为新的节点设置值
teacher.addAttribute("skill","programme");//为新的节点添加属性
}
/**修改内容之三: 若age内容为17,则删除该节点
*未成年人需要被保护...
*/
list= doc.selectNodes("/students/student");//搜索出所有位于students节点下的student节点位置放入集合中
iter= list.iterator();//加载迭代器
//迭代集合
while(iter.hasNext()){
Element elem= (Element)iter.next();
Iterator iterElem= elem.elementIterator("age");//将该节点下所有的age节点生成一个迭代器
//迭代集合
if(iterElem.hasNext()){
Element remTitle= (Element)iterElem.next();
if(remTitle.getText().equals("17"))//对比值
elem.remove(remTitle);//移除该节点
}
}
//将doc中的内容写入文件中
OutputFormat format= OutputFormat.createPrettyPrint();//设置格式
format.setEncoding("GBK");//必要,否则无法解析中文
//输出为文件,以上操作只是在内存中修改,需要保存为文件来确认修改
XMLWriter writer= new XMLWriter(new FileWriter(newFileName),format);
writer.write(doc);
writer.flush();
isOk= true;
}catch(Exception e){
e.printStackTrace();
}
return isOk;
}
/**
*the method readXML
*/
public void readXML(String fileName){
try{
File file= new File(fileName);//创建文件对象
SAXReader reader= new SAXReader();//创建SAX阅读器
Document doc= reader.read(file);//读取内容生成Document对象
Element root= doc.getRootElement();//取得根节点
search(root);//开始遍历
}catch(Exception e){
e.printStackTrace();
}
}
//递归遍历
private void search(Element root) {
Iterator it_element= root.elementIterator();//将根节点下包含的元素组织成一个迭代器
//迭代
while( it_element.hasNext()) {
Element element= (Element)it_element.next();
if(!element.getText().equals(""))
{
System.out.println(element.getName()+"节点的值是"+element.getText());
}
else
{
System.out.println(element.getName()+"节点");
}
Iterator it_attr= element.attributeIterator();
while( it_attr.hasNext()) {
Attribute attr= (Attribute)it_attr.next();
if(attr!=null)
{
System.out.println(element.getName()+"节点的属性"+attr.getName()+ "的值是" + attr.getValue());
}
}
search(element);//递归调用
}
}
/**
*the method main
*/
public static void main(String[] args){
long start= System.currentTimeMillis();//开始计时
Dom4jDemo dom4jDemo= new Dom4jDemo();
String fileName= "dom4jDemo.xml";
String newFileName= "new_dom4jDemo.xml";
System.out.println(fileName+"正在创建中...");
boolean isOk_create= dom4jDemo.createXML(fileName);
if(isOk_create) System.out.println(fileName+"创建成功!");
else System.out.println("创建失败!请检查后重新再试!");
System.out.println("正在更新中...");
boolean isOk_modi= dom4jDemo.modifigXML(fileName, newFileName);
if(isOk_modi) System.out.println("恭喜,更新完成!");
//
System.out.println("正在读取文件"+fileName+" ...");
System.out.println("------------------------------------------------");
dom4jDemo.readXML(fileName);
System.out.println("------------------------------------------------");
System.out.println(fileName+"读取成功!");
System.out.println("正在读取文件"+newFileName+" ...");
System.out.println("------------------------------------------------");
dom4jDemo.readXML(newFileName);
System.out.println("------------------------------------------------");
System.out.println(fileName+"读取成功!");
System.out.println("一共耗时:"+(System.currentTimeMillis()-start)+"毫秒!");
}
}
分享到:
相关推荐
It is adaptable to many different object models, including DOM, XOM, dom4j, and JDOM. Is it also possible to write adapters that treat non-XML trees such as compiled Java byte code or Java beans as ...
《深入理解DOM4J:Java中的XML处理利器》 在Java世界中,处理XML文档是一项常见的任务,而DOM4J库则是实现这一任务的强大工具。DOM4J是Java的一个开源项目,它提供了一套全面而灵活的API来操作XML文档,包括读取、...
Dom4j(Document Object Model for Java)是一个Java语言的开源XML API,它提供了非常便捷的方式来解析、创建以及操作XML文档。相较于其他XML解析库如SAX、JDOM等,Dom4j具有更强大的功能与更好的性能。 为了使用...
dom4j,jsoup,jdom,w3cdom,xstream使用代码工程 package ivyy.taobao.com.dom4j; import ivyy.taobao.com.entity.Address; import ivyy.taobao.com.entity.Location; import ivyy.taobao.com.entity.Point; import ...
标题 "dom4j jars" 和描述 "dom4j jar" 提到的核心知识点是关于 `dom4j` 这个库,它是一个强大的Java XML处理框架。`dom4j` 是一个开源项目,提供了灵活且高效的API来操作XML文档,包括读取、写入、更新以及查询XML...
DOM(Document Object Model)是W3C制定的一种标准,它为XML和HTML文档提供了一种...在2Code和3Code这两个文件中,可能包含了这些库的具体使用示例,学习和理解这些源码可以帮助你更好地掌握DOM、JDOM和dom4j的用法。
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了简单且灵活的方式来解析、创建、修改和查询XML数据。在本文中,我们将深入探讨如何使用DOM4J进行XML操作,包括节点操作、属性操作以及Document对象写入新...
本文将深入探讨如何使用dom4j和jdom两种流行的Java库来解析XML文档,并通过具体的代码示例来展示它们的应用。 ### DOM4J DOM4J(Document Object Model for Java)是一个开放源代码的Java API,用于处理XML文档。...
3. **dom4j-1.6.1.jar**:这是一个强大的XML处理库,可能在这里用于解析或生成XML格式的邮件设置或其他配置文件。 4. **activation.jar**:JavaBeans Activation Framework (JAF) 的JAR文件,它提供了处理和识别...
为了处理XML文档,开发者通常会利用各种解析器,其中DOM4J是一个功能强大且灵活的Java库,适用于XML、XPath和XSLT处理。本篇文章将详细介绍如何使用DOM4J包来解析XML文档。 首先,DOM4J采用Document Object Model...
import org.dom4j.DocumentException; import org.dom4j.DocumentHelper; import org.dom4j.Element; import util.StringUtil; 2. 设置短信接口的 URL:private static String Url = ...
- DOM4J是一个非常流行的Java XML API,它提供了全面且强大的XML解析功能。在动态代理的上下文中,DOM4J可能用来读取XML配置文件,这些文件可能包含关于代理行为的指示。例如,你可以定义哪些方法需要进行额外的...
2. **DOM4J**: 一个轻量级的Java库,用于处理XML。 3. **MyEclipse**: 集成开发环境(IDE),用于编写Java代码。 #### 三、创建XML文件的步骤 ##### 1. 导入必要的包 ```java package com; import java.io.File; ...
本文将详细比较四种常用的XML处理技术:DOM(Document Object Model)、SAX(Simple API for XML)、JDOM和DOM4J,旨在帮助开发人员根据项目需求做出合适的选择。 #### 1. DOM(JAXPCrimson解析器) **定义与特性*...
附带的`jxml3e_code`文件夹可能包含书中示例代码,方便读者动手实践,加深理解。 总之,《Java与XML第三版》是Java开发者深入掌握XML技术,以及在Java应用中有效利用XML的宝贵资源。通过学习,读者将能够充分利用这...
在Java后端,通过日志框架(如Log4j或SLF4J)记录错误信息,便于调试。 6. **安全考虑** - 在前后端交互中,需注意防止XSS(跨站脚本攻击)和CSRF(跨站请求伪造)等安全问题。Java后端应验证请求来源,前端则需要...
- **场景图**:Java 3D使用场景图来组织3D对象,类似于HTML中的DOM树,节点表示3D对象,而边表示对象之间的关系。 - **几何对象**:如立方体、球体、圆柱体等,由顶点、边和面定义,通过`javax.media.j3d.Geometry...
在JavaWeb开发中,DOM解析器如JDOM、DOM4J等被用于处理XML文件。例如,使用DOM解析XML文件,读取、修改或创建XML结构: ```java import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; ...
ZXing是一个开放源代码的多格式一维/二维条码图像处理库,支持多种格式的读取和生成,而qrcode4j则是专门针对二维码操作的Java库。 生成二维码的过程通常包括以下几步: 1. 引入库:根据所选的库,引入相应的依赖...