cachedxpathfunchereapi.java
来自「JAVA 所有包」· Java 代码 · 共 458 行 · 第 1/2 页
JAVA
458 行
/* * Copyright 1999-2004 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */package com.sun.org.apache.xml.internal.security.utils;import com.sun.org.apache.xml.internal.dtm.DTMManager;import com.sun.org.apache.xml.internal.security.transforms.implementations.FuncHere;import com.sun.org.apache.xml.internal.security.transforms.implementations.FuncHereContext;import com.sun.org.apache.xml.internal.utils.PrefixResolver;import com.sun.org.apache.xml.internal.utils.PrefixResolverDefault;import com.sun.org.apache.xpath.internal.CachedXPathAPI;import com.sun.org.apache.xpath.internal.Expression;import com.sun.org.apache.xpath.internal.XPath;import com.sun.org.apache.xpath.internal.XPathContext;import com.sun.org.apache.xpath.internal.compiler.FunctionTable;import com.sun.org.apache.xpath.internal.objects.XObject;import org.w3c.dom.*;import org.w3c.dom.traversal.NodeIterator;import javax.xml.transform.ErrorListener;import javax.xml.transform.SourceLocator;import javax.xml.transform.TransformerException;import java.lang.reflect.Constructor;import java.lang.reflect.Method;import java.lang.reflect.Modifier;/** * * @author $Author: dims $ */public class CachedXPathFuncHereAPI { static java.util.logging.Logger log = java.util.logging.Logger.getLogger(CachedXPathFuncHereAPI.class.getName()); /** * XPathContext, and thus DTMManager and DTMs, persists through multiple * calls to this object. */ FuncHereContext _funcHereContext = null; /** Field _dtmManager */ DTMManager _dtmManager = null; XPathContext _context = null; String xpathStr=null; XPath xpath=null; static FunctionTable _funcTable = null; static { fixupFunctionTable(); } /** * Method getFuncHereContext * @return the context for this object * */ public FuncHereContext getFuncHereContext() { return this._funcHereContext; } /** * Constructor CachedXPathFuncHereAPI * */ private CachedXPathFuncHereAPI() {} /** * Constructor CachedXPathFuncHereAPI * * @param existingXPathContext */ public CachedXPathFuncHereAPI(XPathContext existingXPathContext) { this._dtmManager = existingXPathContext.getDTMManager(); this._context=existingXPathContext; } /** * Constructor CachedXPathFuncHereAPI * * @param previouslyUsed */ public CachedXPathFuncHereAPI(CachedXPathAPI previouslyUsed) { this._dtmManager = previouslyUsed.getXPathContext().getDTMManager(); this._context=previouslyUsed.getXPathContext(); } /** * Use an XPath string to select a single node. XPath namespace * prefixes are resolved from the context node, which may not * be what you want (see the next method). * * @param contextNode The node to start searching from. * @param xpathnode A Node containing a valid XPath string. * @return The first node found that matches the XPath, or null. * * @throws TransformerException */ public Node selectSingleNode(Node contextNode, Node xpathnode) throws TransformerException { return selectSingleNode(contextNode, xpathnode, contextNode); } /** * Use an XPath string to select a single node. * XPath namespace prefixes are resolved from the namespaceNode. * * @param contextNode The node to start searching from. * @param xpathnode * @param namespaceNode The node from which prefixes in the XPath will be resolved to namespaces. * @return The first node found that matches the XPath, or null. * * @throws TransformerException */ public Node selectSingleNode( Node contextNode, Node xpathnode, Node namespaceNode) throws TransformerException { // Have the XObject return its result as a NodeSetDTM. NodeIterator nl = selectNodeIterator(contextNode, xpathnode, namespaceNode); // Return the first node, or null return nl.nextNode(); } /** * Use an XPath string to select a nodelist. * XPath namespace prefixes are resolved from the contextNode. * * @param contextNode The node to start searching from. * @param xpathnode * @return A NodeIterator, should never be null. * * @throws TransformerException */ public NodeIterator selectNodeIterator(Node contextNode, Node xpathnode) throws TransformerException { return selectNodeIterator(contextNode, xpathnode, contextNode); } /** * Use an XPath string to select a nodelist. * XPath namespace prefixes are resolved from the namespaceNode. * * @param contextNode The node to start searching from. * @param xpathnode * @param namespaceNode The node from which prefixes in the XPath will be resolved to namespaces. * @return A NodeIterator, should never be null. * * @throws TransformerException * @deprecated */ public NodeIterator selectNodeIterator( Node contextNode, Node xpathnode, Node namespaceNode) throws TransformerException { // Execute the XPath, and have it return the result XObject list = eval(contextNode, xpathnode, getStrFromNode(xpathnode), namespaceNode); // Have the XObject return its result as a NodeSetDTM. return list.nodeset(); } /** * Use an XPath string to select a nodelist. * XPath namespace prefixes are resolved from the contextNode. * * @param contextNode The node to start searching from. * @param xpathnode * @return A NodeIterator, should never be null. * * @throws TransformerException * @deprecated */ public NodeList selectNodeList(Node contextNode, Node xpathnode) throws TransformerException { return selectNodeList(contextNode, xpathnode, getStrFromNode(xpathnode), contextNode); } /** * Use an XPath string to select a nodelist. * XPath namespace prefixes are resolved from the namespaceNode. * * @param contextNode The node to start searching from. * @param xpathnode * @param str * @param namespaceNode The node from which prefixes in the XPath will be resolved to namespaces. * @return A NodeIterator, should never be null. * * @throws TransformerException */ public NodeList selectNodeList( Node contextNode, Node xpathnode, String str, Node namespaceNode) throws TransformerException { // Execute the XPath, and have it return the result XObject list = eval(contextNode, xpathnode, str, namespaceNode); // Return a NodeList. return list.nodelist(); } /** * Evaluate XPath string to an XObject. Using this method, * XPath namespace prefixes will be resolved from the namespaceNode. * @param contextNode The node to start searching from. * @param xpathnode * @return An XObject, which can be used to obtain a string, number, nodelist, etc, should never be null. * @see com.sun.org.apache.xpath.internal.objects.XObject * @see com.sun.org.apache.xpath.internal.objects.XNull
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?