1

每当我运行下面的代码时,如果它找到了这个词,它会给我一个 Illegalargument 异常,但如果没有匹配,它将一直持续到没有错误结束。有人可以帮我找出解决方案吗?

public static void main(String[] args) throws MalformedURLException, SAXNotRecognizedException, SAXNotSupportedException, ParserConfigurationException, IOException, SAXException, XPathExpressionException {

   Parser p = new Parser();
   SAX2DOM sax2dom = null;
   org.w3c.dom.Node doc  = null;

   URL url = new URL("http://stackoverflow.com/users/1042952/mostafa");

   p.setFeature(Parser.namespacesFeature, false);
   p.setFeature(Parser.namespacePrefixesFeature, false);
   sax2dom = new SAX2DOM();
   p.setContentHandler(sax2dom);
   p.parse(new InputSource(new InputStreamReader(url.openStream())));
   doc = sax2dom.getDOM();

   final String term = "mostafa";
   String expression = "//*[contains(text(),$term)]";
   final QName termVariableName = new QName("term");
   class TermResolver implements XPathVariableResolver {
      @Override
      public Object resolveVariable(QName variableName) {
         return termVariableName.equals(variableName) ? term : null;
      }
   }
   javax.xml.xpath.XPath xpath = XPathFactory.newInstance().newXPath();
   xpath.setXPathVariableResolver(new TermResolver());
   Node node = (Node) xpath.evaluate(expression, p, termVariableName);
   System.out.println("her is it"+node);
}
4

1 回答 1

0

1)您的直接错误是由于传递给的非法结果类型造成的evaluate。从文档

如果 returnType 不是 XPathConstants(NUMBER、STRING、BOOLEAN、NODE 或 NODESET)中定义的类型之一,则抛出 IllegalArgumentException。

2)第二个参数evaluate应该是上下文节点,而不是解析器。

使用这样的东西:

Node node = (Node) xpath.evaluate(expression, doc, XPathConstants.NODE);

注意:您可能打算将Mostafa.

于 2011-11-26T00:23:17.323 回答