From http://www.cnblogs.com/huhu0013/archive/2012/11/09/2762553.html /* * 文件名: XmlUtils.java * 版权信息:CopyRight By liliang ? 2009 * 功能描述:xml操作工具类,提供一些对XML文件常见操作的公有方法。 * 修改人:liliang * 修改时间:2009-06-26 * 修改内容:获取指定节点的属性增加了通过判断是Element后直接使用getAttirubte(name)的方式获取。 */ package com.nnyh.util; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.UnsupportedEncodingException; import java.util.ArrayList; import java.util.List; import javax.xml.namespace.QName; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.transform.OutputKeys; import javax.xml.transform.Transformer; import javax.xml.transform.TransformerException; import javax.xml.transform.TransformerFactory; import javax.xml.transform.dom.DOMSource; import javax.xml.transform.stream.StreamResult; import javax.xml.xpath.XPath; import javax.xml.xpath.XPathConstants; import javax.xml.xpath.XPathExpressionException; import javax.xml.xpath.XPathFactory; import org.w3c.dom.DOMException; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.xml.sax.SAXException; /** * XML文件操作相关的工具类。该类的主要功能有: * * 1.根据xml文件的名字获取Document对象。 * 2.根据字节输入流获取一个Document对象。 * 3.根据字符串获取一个Document对象。 * 4.通过XPath表达式获取单个节点。 * 5.通过XPath表达式获取多个节点。 * 6.通过XPath表达式获取字符串值。 * 7.通过XPath表达式获取布尔值。 * 8.将Document输出到指定的文件。 * 9.获取Node节点的属性值。 * 10.替换node节点。 * 11.将Node节点转换成字符串。 * * * * * @author liliang * @version xmlUtils 1.1 * @since xmlUtils 1.0 * */ public class XmlUtils { /** * 获取Document对象。根据xml文件的名字获取Document对象。 * * @param file * 要获取对象的xml文件全路径。 * @return 返回获取到的Document对象。 * @throws IOException * 如果发生任何 IO 错误时抛出此异常。 * @throws SAXException * 如果发生任何解析错误时抛出此异常。 * @throws ParserConfigurationException * 如果无法创建满足所请求配置的 DocumentBuilder,将抛出该异常。 * @exception NullPointerException * 如果file为空时,抛出此异常。 */ public static Document parseForDoc(final String file) throws SAXException, IOException, SecurityException, NullPointerException, ParserConfigurationException { return XmlUtils.parseForDoc(new FileInputStream(file)); } /** * 将一个xml字符串解析成Document对象。 * * @param xmlStr * 要被解析的xml字符串。 * @param encoding * 字符串的编码。 * @return 返回解析后的Document对象。 * @throws IOException * 如果发生任何 IO 错误时抛出此异常。 * @throws SAXException * 如果发生任何解析错误时抛出此异常。 * @throws ParserConfigurationException * 如果无法创建满足所请求配置的 DocumentBuilder,将抛出该异常。 */ public static Document parseForDoc(String xmlStr, String encoding) throws SAXException, IOException, ParserConfigurationException { if (xmlStr == null) { xmlStr = ""; } ByteArrayInputStream byteInputStream = new ByteArrayInputStream(xmlStr.getBytes(encoding)); return XmlUtils.parseForDoc(byteInputStream); } /** * 获取Document对象。根据字节输入流获取一个Document对象。 * * @param is * 获取对象的字节输入流。 * @return 返回获取到的Document对象。如果出现异常,返回null。 * @throws IOException * 如果发生任何 IO 错误时抛出此异常。 * @throws SAXException * 如果发生任何解析错误时抛出此异常。 * @throws ParserConfigurationException * 如果无法创建满足所请求配置的 DocumentBuilder,将抛出该异常。 * @exception IllegalArgumentException * 当 is 为 null 时抛出此异常。 */ public static Document parseForDoc(final InputStream is) throws SAXException, IOException, ParserConfigurationException, IllegalArgumentException { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); return builder.parse(is); } finally { is.close(); } } /** * 通过xpath表达式解析某个xml节点。 * * @param obj * 要被解析的xml节点对象。 * @param xPath * xpath表达式。 * @param qName * 被解析的目标类型。 * @return 返回解析后的对象。 * @throws XPathExpressionException * 如果不能计算 expression。 * * @exception RuntimeException * 创建默认对象模型的 XPathFactory 遇到故障时。 * @exception NullPointerException * 如果xPath为空时抛出时异常。 */ private static Object parseByXpath(final Object obj, final String xPath, QName qName) throws NullPointerException, RuntimeException, XPathExpressionException { XPathFactory xpathFactory = XPathFactory.newInstance(); XPath path = xpathFactory.newXPath(); return path.evaluate(xPath, obj, qName); } /** * 通过XPath表达式获取单个节点。 * * @param obj * 要被解析的對象。 * @param xPath * XPath表达式。 * @return 返回获取到的节点。 * * @throws XPathExpressionException * 如果不能计算 expression。 * * @exception RuntimeException * 创建默认对象模型的 XPathFactory 遇到故障时。 * @exception NullPointerException * 如果xPath为空时抛出时异常。 */ public static Node parseForNode(final Object obj, final String xPath) throws NullPointerException, RuntimeException, XPathExpressionException { return (Node) XmlUtils.parseByXpath(obj, xPath, XPathConstants.NODE); } /** * 通过XPath表达式获取某个xml节点的字符串值。 * * @param obj * 要被解析的對象。 * @param xPath * XPath表达式。 * @return 返回获取到的节点的字符串值。 * * @throws XPathExpressionException * 如果不能计算 expression。 * * @exception RuntimeException * 创建默认对象模型的 XPathFactory 遇到故障时。 * @exception NullPointerException * 如果xPath为空时抛出时异常。 */ public static String parseForString(final Object obj, final String xPath) throws NullPointerException, RuntimeException, XPathExpressionException { return (String) XmlUtils.parseByXpath(obj, xPath, XPathConstants.STRING); } /** * 通过XPath表达式获取某个xml节点的布尔值。 * * @param obj * 要被解析的對象。 * @param xPath * XPath表达式。 * @return 返回获取到的节点的布尔值。 * * @throws XPathExpressionException * 如果不能计算 expression。 * * @exception RuntimeException * 创建默认对象模型的 XPathFactory 遇到故障时。 * @exception NullPointerException * 如果xPath为空时抛出时异常。 */ public static Boolean parseForBoolean(final Object obj, final String xPath) throws NullPointerException, RuntimeException, XPathExpressionException { return (Boolean) XmlUtils.parseByXpath(obj, xPath, XPathConstants.BOOLEAN); } /** * 通过XPath表达式获取Node列表。 * * @param obj * 要被解析的對象。 * @param xPath * XPath表达式。 * @return 返回获取到的Node列表。 * * @throws XPathExpressionException * 如果不能计算 expression。 * * @exception RuntimeException * 创建默认对象模型的 XPathFactory 遇到故障时。 * @exception NullPointerException * 如果xPath为空时抛出时异常。 */ public static List parseForNodeList(final Object obj, final String xPath) throws NullPointerException, RuntimeException, XPathExpressionException { List lists = new ArrayList(); NodeList nList = (NodeList) XmlUtils.parseByXpath(obj, xPath, XPathConstants.NODESET); if (nList != null) { for (int i = 0; i < nList.getLength(); i++) { lists.add(nList.item(i)); } } return lists; } /** * 获取节点的制定属性。 * * @param node * 节点。 * @param attrName * 属性名。 * @return 返回获取到的属性值。如果找不到相关的 * */ public static String getAttribute(final Object node, final String attrName) { String result = ""; if ((node != null) && (node instanceof Node)) { if (((Node) node).getNodeType() == Node.ELEMENT_NODE) { result = ((Element) node).getAttribute(attrName); } else { // 遍历整个xml某节点指定的属性 NamedNodeMap attrs = ((Node) node).getAttributes(); if ((attrs.getLength() > 0) && (attrs != null)) { Node attr = attrs.getNamedItem(attrName); result = attr.getNodeValue(); } } } return result; } /** * 使用新节点替换原来的旧节点。 * * @param oldNode * 要被替换的旧节点。 * @param newNode * * 替换后的新节点。 * @exception DOMException * 如果此节点为不允许 * newNode节点类型的子节点的类型;或者如果要放入的节点为此节点的一个祖先或此节点本身;或者如果此节点为 * Document 类型且替换操作的结果将第二个 DocumentType 或 Element 添加到 * Document 上。 WRONG_DOCUMENT_ERR: 如果 newChild * 是从不同的文档创建的,不是从创建此节点的文档创建的,则引发此异常。 * NO_MODIFICATION_ALLOWED_ERR: 如果此节点或新节点的父节点为只读的,则引发此异常。 * NOT_FOUND_ERR: 如果 oldChild 不是此节点的子节点,则引发此异常。 * NOT_SUPPORTED_ERR: 如果此节点为 Document 类型,则如果 DOM 实现不支持替换 * DocumentType 子节点或 Element 子节点,则可能引发此异常。 */ public static void replaceNode(Node oldNode, Node newNode) { if ((oldNode != null) && (newNode != null)) { oldNode.getParentNode().replaceChild(newNode, oldNode); } } /** * 将Document输出到指定的文件中。 * * @param fileName * 文件名。 * @param node * 要保存的对象。 * @param encoding * 保存的编码。 * @throws FileNotFoundException * 指定的文件名不存在时,抛出此异常。 * @throws TransformerException * 如果转换过程中发生不可恢复的错误时,抛出此异常。 */ public static void saveXml(final String fileName, final Node node, String encoding) throws FileNotFoundException, TransformerException { XmlUtils.writeXml(new FileOutputStream(fileName), node, encoding); } /** * 将Document输出成字符串的形式。 * * @param node * Node对象。 * @param encoding * 字符串的编码。 * @return 返回输出成的字符串。 * @throws TransformerException * 如果转换过程中发生不可恢复的错误时,抛出此异常。 * @throws UnsupportedEncodingException * 指定的字符串编码不支持时,抛出此异常。 */ public static String nodeToString(Node node, String encoding) throws TransformerException, UnsupportedEncodingException { ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); XmlUtils.writeXml(outputStream, node, encoding); return outputStream.toString(encoding); } /** * 将指定的Node写到指定的OutputStream流中。 * * @param encoding * 编码。 * @param os * OutputStream流。 * @param node * Node节点。 * @throws TransformerException * 如果转换过程中发生不可恢复的错误时,抛出此异常。 */ private static void writeXml(OutputStream os, Node node, String encoding) throws TransformerException { TransformerFactory transFactory = TransformerFactory.newInstance(); Transformer transformer = transFactory.newTransformer(); transformer.setOutputProperty("indent", "yes"); transformer.setOutputProperty(OutputKeys.ENCODING, encoding); DOMSource source = new DOMSource(); source.setNode(node); StreamResult result = new StreamResult(); result.setOutputStream(os); transformer.transform(source, result); } }
相关推荐
2. **性能优化**: 相比于W3C DOM,jdom在内存使用和性能上有一定的优势,特别是在处理小到中等大小的XML文档时。 3. **简化API**: jdom的API设计简洁,易于学习和使用,减少了学习成本。 4. **流式处理**: 虽然jdom...
在Java中,`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`类可用于构建和操作DOM树。 3. **SAX(Simple API for XML)**:SAX是一种事件驱动的解析器,它不会将整个XML文档加载到内存中,...
SAX解析器适用于处理大型XML文件,DOM适用于小型文件并需要对整个文档进行操作,DOM4J和JDOM则提供了更高级的功能,如XPath查询,适用于复杂的数据操作。在实际开发中,开发者可以根据需求灵活选择合适的XML解析方式...
为了更好地理解如何在Android应用中使用XML,本文通过一个具体的案例——Android新闻阅读器来进行讲解。该应用的目标是从Androidster网站获取RSS提要,并将其解析为一系列的`Message`对象,最终展示在一个`ListView`...
8. **jQuery和其他库**:虽然原生DOM API强大,但使用起来相对繁琐。jQuery等库封装了DOM操作,提供了简洁的API,简化了开发工作。 理解并熟练运用DOM对象是Web开发中的基础技能,无论是在JavaScript、TypeScript或...
在Android中,可以使用`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`等类来实现DOM解析。 首先,我们需要创建一个`DocumentBuilder`实例,然后用它来解析XML文件,得到`Document`对象。例如...
首先,我们需要了解JDK中处理XML的主要API,包括`javax.xml.parsers`包下的`DocumentBuilderFactory`和`DocumentBuilder`,以及`org.w3c.dom`包下的`Document`接口。这些API提供了一种基于W3C DOM(文档对象模型)的...
最终,基于SGML的简化版本,XML在1998年由W3C(World Wide Web Consortium)发布,旨在提供一种更加灵活的数据表示和交换方式。 随着互联网的发展和技术的进步,XML逐渐被广泛应用于多种场景,如XHTML、WML等,这些...
- **XSL 转换**:讨论如何在 ORACLE XML DB 中使用 XSLT 对 XML 文档进行转换。 #### 五、总结 ORACLE XML DB 为用户提供了一种强大的工具,不仅可以高效地存储和检索 XML 数据,还能充分利用 Oracle 数据库本身的...
Android中使用`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`接口来实现DOM解析。这种方法适用于小型XML文件,因为将整个文档加载到内存可能消耗大量资源。 2. SAX解析 SAX(Simple API for ...
命名空间使用`xmlns`属性定义,并可以关联一个URI(统一资源标识符),如`xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"`。 3. **DTD(Document Type Definition)与XML Schema**:这两种是定义XML文档...
JDOM是Java特定的DOM实现,它的设计目标是为了解决原生DOM在处理大型XML文档时性能较低的问题。JDOM提供了更高效的内存模型和API,使得在Java环境中处理XML更加便捷。JDOM允许开发者直接通过XML元素名来创建和操作...
4. **标准化**:XML有严格的语法规则,并且由W3C组织进行维护和推广。 **Ajax与XML的结合** 在Ajax中,XML通常作为服务器端与客户端之间交换数据的格式。以下是一个简单的Ajax调用XML数据的流程: 1. **创建...
除了使用第三方库,Android还提供了一种基于注解的序列化方式,即`org.w3c.dom.Element`和`javax.xml.transform`。这种方式相对复杂,但可以避免引入额外的依赖。你可以创建一个继承自`Serializable`的类,然后使用`...
这些工具通常比原生DOM API更易用且高效。 **学习资源** 除了《JavaScript DOM编程艺术》这本书,网上有许多优质的教程和资源可供学习,如MDN Web文档、W3Schools和Codecademy等。同时,实践是最好的老师,通过构建...
jQuery使得JavaScript编程更加简洁和高效,但随着现代浏览器对原生API的支持加强,使用轻量级的替代库或直接使用ES6+的特性已成为趋势。 **XML** XML(eXtensible Markup Language)是一种用于标记数据的语言,...
XML是数据交换的常用格式,Java提供了多种解析XML的库,如DOM4J,它基于W3C的DOM标准,方便地解析和操作XML文档。`Properties`类则用于处理配置文件,通常用于存储应用程序的配置参数,如数据库连接信息等。 在集合...
W3C的标准包括XML Schema、XSLT、DOM、XLink 和 XQuery,这些标准已经相当成熟并广泛采用。 ## 引言 随着信息技术的发展,数据交换的需求日益增加。XML(可扩展标记语言)因其灵活性和跨平台兼容性而成为数据交换...
DOM(Document Object Model)是W3C推荐的一种XML和HTML的API,它将XML文档视为一个树形结构,允许开发者通过对象模型来访问和操作XML文档。DOM解析器会一次性加载整个XML文档到内存,形成一个完整的DOM树,因此适合...