java - 使用 VTD-XML 的 log4j.xml 上的 XPath

标签 java xml xpath vtd-xml

我有这样的 validLog4jXML 字符串

<?xml version="1.0" encoding="ISO-8859-1" ?> 
<!DOCTYPE log4j:eventSet PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd" >
<log4j:eventSet version="1.2" xmlns:log4j="http://jakarta.apache.org/log4j/" includesLocationInfo="true">
    <log4j:event logger="org.apache.axis2.deployment.ClusterBuilder" 
        timestamp="1395925603261" level="INFO" thread="localhost-startStop-1">
        <log4j:message>
            <![CDATA[Clustering has been disabled]]>
        </log4j:message>
    </log4j:event>
</log4j:eventSet>

我尝试运行此代码:

VTDGen doc = new VTDGen();
doc.setDoc(validLog4jXML.getBytes());
doc.parse(true);
VTDNav vn = doc.getNav();
AutoPilot ap = new AutoPilot(vn);
String xPath = "//log4j:event[(((@level=\"INFO\") or (@level=\"ERROR\")) and "
            + "(@timestamp>\"1395842943674\")) and (@timestamp<\"1396015743674\")]";
ap.selectXPath(xPath);

在最后一行我遇到异常:

[ERROR] No URL found for prefix:log4j
com.ximpleware.XPathParseException: No URL found for prefix:log4j
    at com.ximpleware.xpath.CUP$parser$actions.CUP$parser$do_action(parser.java:752)
    at com.ximpleware.xpath.parser.do_action(parser.java:434)
    at java_cup.runtime.lr_parser.parse(lr_parser.java:570)
    at com.ximpleware.AutoPilot.selectXPath(AutoPilot.java:809)
    at ad.ecs.library.LogHelper.collectLogNodesVTD(LogHelper.java:654)
    at ad.ecs.library.LogHelper.collectLogNodesForADayVTD(LogHelper.java:571)
    at ad.ecs.library.LogHelper.collectLogNodesForTheWeekVTD(LogHelper.java:456)
    at ad.ecs.library.LogHelper.access$2(LogHelper.java:453)
    at ad.ecs.library.LogHelper$2.run(LogHelper.java:313)
    at java.lang.Thread.run(Thread.java:724)

我尝试查看有关 VTD-XML 的文档,它说:

要避免此异常:

com.ximpleware.XPathParseException: No URL found for prefix:xyz

确保创建具有命名空间支持的初始导航器对象(即,最后一个参数设置为 true),并将命名空间哈希作为最终参数传递给 find-indexes、first-match、all-matches 、get-xml 和 get-hash。

我尝试按照这些步骤进行操作,但没有成功。我将不胜感激任何帮助。

最佳答案

您必须先注册命名空间,然后才能在查询中使用declareXPathNameSpace :

ap.declareXPathNameSpace(log4j, "http://jakarta.apache.org/log4j/");

关于java - 使用 VTD-XML 的 log4j.xml 上的 XPath,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22717078/

相关文章:

c# - 请求中的错误 SOAP 操作 header 。为什么?

java - 为什么 Adapter 多次向 ListView 添加相同的位置?

xml - XSLT:更改某些属性值

xml - 如何获取XPATH属性数量

java jlabel 单击/拖动

java - 如何使用java跟踪MS Access数据库的每个操作

java - Tomcat 和 vHost 在特定子目录上失败

java - 服务请求后停止 HttpServer

Java - 指定要在 REST 中返回的字段

xml - Xpath 结果与 xs :assert result