All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javax.xml.xpath.package-info Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2015, 2021, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

/**
 *
 * Provides an object-model neutral API for the
 * evaluation of XPath expressions and access to the evaluation
 * environment.
 *
 * 

* The XPath API supports * XML Path Language (XPath) Version 1.0 * *


* * *

* *

1. XPath Overview

* *

* The XPath language provides a simple, concise syntax for selecting * nodes from an XML document. XPath also provides rules for converting a * node in an XML document object model (DOM) tree to a boolean, double, * or string value. XPath is a W3C-defined language and an official W3C * recommendation; the W3C hosts the XML Path Language (XPath) Version * 1.0 specification. * * *

* XPath started in life in 1999 as a supplement to the XSLT and * XPointer languages, but has more recently become popular as a * stand-alone language, as a single XPath expression can be used to * replace many lines of DOM API code. * * * *

2. XPath Expressions

* *

* An XPath expression is composed of a location * path and one or more optional predicates. Expressions * may also include XPath variables. * * *

* The following is an example of a simple XPath expression: * *

*
 *     /foo/bar
 * 
*
* *

* This example would select the {@code } element in * an XML document such as the following: * *

*
 *     <foo>
 *         <bar/>
 *     </foo>
 * 
*
* *

The expression {@code /foo/bar} is an example of a location * path. While XPath location paths resemble Unix-style file system * paths, an important distinction is that XPath expressions return * all nodes that match the expression. Thus, all three * {@code } elements in the following document would be * selected by the {@code /foo/bar} expression: * *

*
 *     <foo>
 *         <bar/>
 *         <bar/>
 *         <bar/>
 *     </foo>
 * 
*
* *

* A special location path operator, {@code //}, selects nodes at * any depth in an XML document. The following example selects all * {@code } elements regardless of their location in a * document: * *

*
 *     //bar
 * 
*
* *

* A wildcard operator, *, causes all element nodes to be selected. * The following example selects all children elements of a * {@code } element: * *

*
 *     /foo/*
 * 
*
* *

* In addition to element nodes, XPath location paths may also address * attribute nodes, text nodes, comment nodes, and processing instruction * nodes. The following table gives examples of location paths for each * of these node types: * *

* * * * * * * * * * * * * * * * * * * * * * * * * *
Examples of Location Path
Location PathDescription
* /foo/bar/@id * * Selects the attribute {@code id} of the {@code } element *
/foo/bar/text() * * Selects the text nodes of the {@code } element. No * distinction is made between escaped and non-escaped character data. *
/foo/bar/comment() * * Selects all comment nodes contained in the {@code } element. *
/foo/bar/processing-instruction() * * Selects all processing-instruction nodes contained in the * {@code } element. *
* *

* Predicates allow for refining the nodes selected by an XPath * location path. Predicates are of the form * [expression]. The following example selects all * {@code } elements that contain an {@code include} * attribute with the value of {@code true}: * *

*
 *     //foo[@include='true']
 * 
*
* *

* Predicates may be appended to each other to further refine an * expression, such as: * *

*
 *     //foo[@include='true'][@mode='bar']
 * 
*
* * *

3. XPath Data Types

* *

* While XPath expressions select nodes in the XML document, the XPath * API allows the selected nodes to be coalesced into one of the * following data types: * *

    *
  • {@code Boolean}
  • *
  • {@code Number}
  • *
  • {@code String}
  • *
* * *

3.1 QName types

* The XPath API defines the following {@link javax.xml.namespace.QName} types to * represent return types of an XPath evaluation: *
    *
  • {@link javax.xml.xpath.XPathConstants#NODESET}
  • *
  • {@link javax.xml.xpath.XPathConstants#NODE}
  • *
  • {@link javax.xml.xpath.XPathConstants#STRING}
  • *
  • {@link javax.xml.xpath.XPathConstants#BOOLEAN}
  • *
  • {@link javax.xml.xpath.XPathConstants#NUMBER}
  • *
* *

* The return type is specified by a {@link javax.xml.namespace.QName} parameter * in method call used to evaluate the expression, which is either a call to * {@code XPathExpression.evalute(...)} or {@code XPath.evaluate(...)} * methods. * *

* When a {@code Boolean} return type is requested, * {@code Boolean.TRUE} is returned if one or more nodes were * selected; otherwise, {@code Boolean.FALSE} is returned. * *

* The {@code String} return type is a convenience for retrieving * the character data from a text node, attribute node, comment node, or * processing-instruction node. When used on an element node, the value * of the child text nodes is returned. * *

* The {@code Number} return type attempts to coalesce the text * of a node to a {@code double} data type. * * *

3.2 Class types

* In addition to the QName types, the XPath API supports the use of Class types * through the {@code XPathExpression.evaluateExpression(...)} or * {@code XPath.evaluateExpression(...)} methods. * * The XPath data types are mapped to Class types as follows: *
    *
  • {@code Boolean} -- {@code Boolean.class}
  • *
  • {@code Number} -- {@code Number.class}
  • *
  • {@code String} -- {@code String.class}
  • *
  • {@code Nodeset} -- {@code XPathNodes.class}
  • *
  • {@code Node} -- {@code Node.class}
  • *
* *

* Of the subtypes of {@code Number}, only {@code Double, Integer} and {@code Long} are supported. * * *

3.3 Enum types

* Enum types are defined in {@link javax.xml.xpath.XPathEvaluationResult.XPathResultType} * that provide mappings between the QName and Class types above. The result of * evaluating an expression using the {@code XPathExpression.evaluateExpression(...)} * or {@code XPath.evaluateExpression(...)} methods will be of one of these types. *

* Note the differences between the Enum and QName * mappings: *

    *
  • {@link javax.xml.xpath.XPathConstants#NUMBER NUMBER}
    * The Enum mapping for {@link javax.xml.xpath.XPathConstants#NUMBER NUMBER} * supports {@code Double, Integer} and {@code Long}.

    *
  • *
  • {@link javax.xml.xpath.XPathConstants#NODESET NODESET}
    * The Enum mapping for {@link javax.xml.xpath.XPathConstants#NODESET NODESET} * is {@link javax.xml.xpath.XPathNodes XPathNodes} instead of * {@link org.w3c.dom.NodeList NodeList} in the * QName mapping. *
  • *
* * *

4. XPath Context

* *

* XPath location paths may be relative to a particular node in the * document, known as the {@code context}. A context consists of: *

    *
  • a node (the context node)
  • *
  • a pair of non-zero positive integers (the context position and the context size)
  • *
  • a set of variable bindings
  • *
  • a function library
  • *
  • the set of namespace declarations in scope for the expression
  • *
* *

* It is an XML document tree represented as a hierarchy of nodes, a * {@link org.w3c.dom.Node} for example, in the JDK implementation. * * *

5. Using the XPath API

* * Consider the following XML document: *
*
 * <widgets>
 * <widget>
 * <manufacturer/>
 * <dimensions/>
 * </widget>
 * </widgets>
 * 
*
* *

* The {@code } element can be selected with the following process: * *

*
 *     // parse the XML as a W3C Document
 *     DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
 *     Document document = builder.parse(new File("/widgets.xml"));
 *
 *     //Get an XPath object and evaluate the expression
 *     XPath xpath = XPathFactory.newInstance().newXPath();
 *     String expression = "/widgets/widget";
 *     Node widgetNode = (Node) xpath.evaluate(expression, document, XPathConstants.NODE);
 *
 *     //or using the evaluateExpression method
 *     Node widgetNode = xpath.evaluateExpression(expression, document, Node.class);
 * 
*
* *

* With a reference to the {@code } element, a * relative XPath expression can be written to select the * {@code } child element: * *

*
 *     XPath xpath = XPathFactory.newInstance().newXPath();
 *     String expression = "manufacturer";
 *     Node manufacturerNode = (Node) xpath.evaluate(expression, widgetNode, XPathConstants.NODE);
 *
 *     //or using the evaluateExpression method
 *     Node manufacturerNode = xpath.evaluateExpression(expression, widgetNode, Node.class);
 * 
*
* *

* In the above example, the XML file is read into a DOM Document before being passed * to the XPath API. The following code demonstrates the use of InputSource to * leave it to the XPath implementation to process it: * *

*
 *     XPath xpath = XPathFactory.newInstance().newXPath();
 *     String expression = "/widgets/widget";
 *     InputSource inputSource = new InputSource("widgets.xml");
 *     NodeList nodes = (NodeList) xpath.evaluate(expression, inputSource, XPathConstants.NODESET);
 *
 *     //or using the evaluateExpression method
 *     XPathNodes nodes = xpath.evaluateExpression(expression, inputSource, XPathNodes.class);
 * 
*
* *

* In the above cases, the type of the expected results are known. In case where * the result type is unknown or any type, the {@link javax.xml.xpath.XPathEvaluationResult} * may be used to determine the return type. The following code demonstrates the usage: *

*
 *     XPathEvaluationResult<?> result = xpath.evaluateExpression(expression, document);
 *     switch (result.type()) {
 *         case NODESET:
 *             XPathNodes nodes = (XPathNodes)result.value();
 *             ...
 *             break;
 *     }
 * 
*
* *

* The XPath 1.0 Number data type is defined as a double. However, the XPath * specification also provides functions that returns Integer type. To facilitate * such operations, the XPath API allows Integer and Long to be used in * {@code evaluateExpression} method such as the following code: *

*
 *     int count = xpath.evaluateExpression("count(/widgets/widget)", document, Integer.class);
 * 
*
* * @since 1.5 * */ package javax.xml.xpath;




© 2015 - 2024 Weber Informatics LLC | Privacy Policy