Java操作XML工具类XmlUtil详解

本文实例为大家分享了Java操作XML工具类的具体代码,供大家参考,具体内容如下

一、代码

public class XmlUtil {
 /**
 * 将XML文件输出到指定的路径
 *
 * @param doc
 * @param fileName
 * @throws Exception
 */
 public static void outputXml(Document doc, String fileName)
 throws Exception {
 TransformerFactory tf = TransformerFactory.newInstance();
 Transformer transformer = tf.newTransformer();
 DOMSource source = new DOMSource(doc);
 transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
 transformer.setOutputProperty(OutputKeys.INDENT, "yes");
 PrintWriter pw = new PrintWriter(new FileOutputStream(fileName));
 StreamResult result = new StreamResult(pw);
 transformer.transform(source, result);
 System.out.println("生成XML文件成功!");
 }

 /**
 * 生成XML
 *
 * @param ip
 * @return
 */
 public static Document generateXml(String ip) {
 Document doc = null;
 Element root = null;
 try {
 DocumentBuilderFactory factory = DocumentBuilderFactory
  .newInstance();
 DocumentBuilder builder = factory.newDocumentBuilder();
 doc = builder.newDocument();
 root = doc.createElement("errorDevices");
 doc.appendChild(root);
 } catch (Exception e) {
 e.printStackTrace();
 return null;// 如果出现异常,则不再往下执行
 }

 Element element;
 element = doc.createElement("errorDevice");
 element.setAttribute("ip", ip);
 element.setAttribute("date",
 StringUtil.formatDate(new Date(), "yyyy-MM-dd hh:mm:ss"));
 element.setAttribute("status", "1");
 root.appendChild(element);
 return doc;
 }

 /**
 * 新增Xml节点
 *
 * @param ip
 * @param fileName
 * @return
 * @throws FileNotFoundException
 * @throws TransformerException
 */
 public static void toWrite(String filename, String ip)
 throws FileNotFoundException, TransformerException {
 String date = StringUtil.formatDate(new Date(), "yyyy-MM-dd hh:mm:ss");
 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
 DocumentBuilder builder = null;
 Document doc = null;
 try {
 builder = factory.newDocumentBuilder();
 doc = builder.parse(new File(filename));
 } catch (ParserConfigurationException e) {
 e.printStackTrace();
 } catch (SAXException e) {
 e.printStackTrace();
 } catch (IOException e) {
 e.printStackTrace();
 }
 NodeList links = doc.getElementsByTagName("errorDevice");
 if (links.getLength() > 0) {
 for (int i = 0; i < links.getLength(); i++) {
 Node nd = links.item(i);
 Node catParent = nd.getParentNode();
 Element ele = (Element) nd;
 String url = ele.getAttribute("ip");
 if (url.equals(ip)) {
  // ele.setAttribute("date", date);
  catParent.removeChild(nd);
 }
 }
 }
 Element element = doc.createElement("errorDevice");
 element.setAttribute("ip", ip);
 element.setAttribute("date",
 StringUtil.formatDate(new Date(), "yyyy-MM-dd hh:mm:ss"));
 element.setAttribute("status", "1");
 doc.getDocumentElement().appendChild(element);
 TransformerFactory tf = TransformerFactory.newInstance();
 Transformer transformer = tf.newTransformer();
 DOMSource source = new DOMSource(doc);
 transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
 transformer.setOutputProperty(OutputKeys.INDENT, "yes");
 PrintWriter pw = new PrintWriter(new FileOutputStream(filename));
 StreamResult result = new StreamResult(pw);
 transformer.transform(source, result);
 System.out.println("新增XML节点成功!");
 }

 /**
 * 读取XML
 *
 * @param filename
 * @return
 */
 public static List<Map> readXml(String filename){
 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
 DocumentBuilder builder = null;
 Document doc = null;
 try {
 builder = factory.newDocumentBuilder();
 doc = builder.parse(new File(filename));
 } catch (ParserConfigurationException e) {
 e.printStackTrace();
 } catch (SAXException e) {
 e.printStackTrace();
 } catch (IOException e) {
 e.printStackTrace();
 }
 NodeList links = doc.getElementsByTagName("errorDevice");
 List<Map> list = new ArrayList<Map>();
 for(int i = 0; i< links.getLength() ; i ++){
   Element node = (Element)links.item(i);
   Map map = new HashMap();
   map.put(node.getAttribute("ip"), node.getAttribute("date"));
   list.add(map);
 }
 return list;
 }
}

二、演示XML

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<errorDevices>
 <errorDevice date="2017-03-13 12:54:16" ip="20.100.156.42" status="1"/>
 <errorDevice date="2017-03-13 12:54:56" ip="20.100.156.41" status="1"/>
</errorDevices>

三、最终效果图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java中四种操作xml方式的比较

    1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以在任何时候在树中上下导航,而不是像SAX那

  • java实现XML增加元素操作简单示例

    本文实例讲述了java实现XML增加元素操作.分享给大家供大家参考,具体如下: package Day01; import java.io.*; import javax.xml.parsers.*; import javax.xml.transform.*; import javax.xml.transform.dom.DOMSource; import javax.xml.transform.stream.StreamResult; import org.w3c.dom.*; public

  • java使用jaxb操作xml示例

    首先定义两个示例类ClassA,ClassB,用于后续的示例演示 复制代码 代码如下: package cn.lzrabbit; public class ClassA {     private int classAId;     private String classAName; private ClassB classB; public int getClassAId() {         return classAId;     } public void setClassAId(i

  • java操作xml的方法汇总及解析

    这篇文章主要介绍了java操作xml的方法汇总及解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一丶常用方法 主要有3个方面, 1读取xml文件, 2使用xpath根据指定路径获取某一节点数据 3, xml和java bean的转换 XmlUtils.java /** * 和cn.hutool.core.util.XmlUtil许多功能重合, 本类可以当做学习的例子 * 可以直接使用cn.hutool.core.util.XmlUtil *

  • java对XML文件的解析、节点的增加、删除操作总结

    1.java代码: 主要采用dom来进行操作 复制代码 代码如下: package test; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.transform.T

  • java使用DOM4J对XML文件进行增删改查操作

    本文实例为大家分享了java使用DOM4J对XML文件进行增删改查操作的具体代码,供大家参考,具体内容如下 源代码: DOM4j.java package com.zc.homeWork19; import java.io.FileWriter; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import org.dom4j.Document; import org.dom4j.Elem

  • java操作(DOM、SAX、JDOM、DOM4J)xml方式的四种比较与详解

    1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以在任何时候在树中上下导航,而不是像SAX那

  • Java对XML文件增删改查操作示例

    本文实例讲述了Java对XML文件增删改查操作.分享给大家供大家参考,具体如下: xml文件: <?xml version="1.0" encoding="UTF-8"?> <books> <book> <name>哈里波特</name> <price>10</price> <memo>这是一本很好看的书.</memo> </book> <b

  • Java操作XML工具类XmlUtil详解

    本文实例为大家分享了Java操作XML工具类的具体代码,供大家参考,具体内容如下 一.代码 public class XmlUtil { /** * 将XML文件输出到指定的路径 * * @param doc * @param fileName * @throws Exception */ public static void outputXml(Document doc, String fileName) throws Exception { TransformerFactory tf = T

  • Java多线程同步工具类CountDownLatch详解

    目录 简介 核心方法 CountDownLatch如何使用 CountDownLatch运行流程 运用场景 总结 简介 CountDownLatch是一个多线程同步工具类,在多线程环境中它允许多个线程处于等待状态,直到前面的线程执行结束.从类名上看CountDown既是数量递减的意思,我们可以把它理解为计数器. 核心方法 countDown():计数器递减方法. await():使调用此方法的线程进入等待状态,直到计数器计数为0时主线程才会被唤醒. await(long, TimeUnit):在

  • Java日期处理工具类DateUtils详解

    本文实例为大家分享了Java日期处理工具类DateUtils的具体代码,供大家参考,具体内容如下 import java.sql.Timestamp; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; /** * <日期时间处理工具类> */ public class DateUtils { /** * Dat

  • Java操作集合工具类Collections使用详解

    这篇文章主要介绍了java操作集合工具类Collections使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Collections是一个操作Set.List和Map等集合的工具类. Collections中提供了大量方法对集合元素进行排序.查询和修改等操作,还提供了对集合对象设置不可变.对集合对象实现同步控制等方法. 排序操作: reverse(List):反转List中元素的顺序: shuffle(List):对List集合元素进行

  • java操作mongoDB查询的实例详解

    java操作mongo查询的实例详解 前言: MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型.Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且

  • java线程池ThreadPoolExecutor类使用详解

    在<阿里巴巴java开发手册>中指出了线程资源必须通过线程池提供,不允许在应用中自行显示的创建线程,这样一方面是线程的创建更加规范,可以合理控制开辟线程的数量:另一方面线程的细节管理交给线程池处理,优化了资源的开销.而线程池不允许使用Executors去创建,而要通过ThreadPoolExecutor方式,这一方面是由于jdk中Executor框架虽然提供了如newFixedThreadPool().newSingleThreadExecutor().newCachedThreadPool(

  • Java异步编程工具Twitter Future详解

    目录 异步编程(Twitter Future) 为啥要异步 基本用法 1.封装计算逻辑,异步返回. 2.异步计算结果串联异步处理 3.并行多个异步任务,统一等待结果 4.异步错误处理 Twitter包装 pom依赖 1.封装计算逻辑,异步返回 2.异步计算结果串联异步处理 3.并行多个异步任务 4.错误处理 其他用法 其他工具 异步编程(Twitter Future) 为啥要异步 异步编程有点难以理解,这东西感觉不符合常理,因为我们思考都是按照串行的逻辑,事都是一件一件办.但在异步计算的情况下,

  • java开发中嵌套类的详解及实例

     java开发中嵌套类的详解 在java语言规范里面,嵌套类(Nested Classes)定义是: A nested class is any class whose declaration occurs within the body of another class or interface. A top level class is a class that is not a nested class. 说的简单一点,就是定义在类里面的类.一般把定义内部类的外围类成为包装类(enclos

  • java Arrays工具类实例详解

    Arrays工具类属于java中常用的工具类 public static void sort(int[] a) public static void sort(int[] a,int fromIndex, int toIndex) public static void sort(long[] a) public static void sort(long[] a,int fromIndex, int toIndex) public static void sort(short[] a) publ

  • Java中JSON处理工具类使用详解

    本文实例为大家分享了JSON处理工具类的具体代码,供大家参考,具体内容如下 import java.io.IOException; import java.util.Date; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletResponse; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.seri

随机推荐