获取xsi的值:noNamespaceSchemaLocation(XPATH)

时间:2014-01-23 15:07:43

标签: java xpath xsi

更新

我想在xsi:noNamespaceSchemaLocation中获取arritbute的值,也就是说:“http://www.mypage/pagedescription.xsd

<link 
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 xsi:noNamespaceSchemaLocation="http://www.mypage/pagedescription.xsd">


 ...
 ...

link是我的XML文件中的一个元素(几乎在顶部)

但是,XPATH // n:link / @ xsi:noNamespaceSchemaLocation不起作用

我试图修改上下文,但它仍然不起作用

@Override
public Object executeXpathQuery(Document domDoc, String strQuery) throws Exception {


    System.out.println("executeXpathQuery : strQuery:" + strQuery);

    // output: executeXpathQuery:  strQuery://n:link/@xsi:noNamespaceSchemaLocation
    // so far, it looks OK

    XPathFactory xpf = XPathFactory.newInstance();
    XPath xPath = xpf.newXPath();

    final String nonameNamespace = domDoc.getFirstChild().getNamespaceURI();

    NamespaceContext ctx = new NamespaceContext() {
        public String getNamespaceURI(String prefix) {

            String uri = null;
            if ("n".equals(prefix)) {
                System.out.println("using prefix");
                uri = nonameNamespace;
            } 
            else if ("xsi".equals(prefix)) {
                 uri = "http://www.w3.org/2001/XMLSchema-instance";
            }
            return null;
        }
        public String getPrefix(String uri) {
            throw new UnsupportedOperationException();
        }
        public Iterator getPrefixes(String uri) {
            throw new UnsupportedOperationException();
         }
    };


    xPath.setNamespaceContext(ctx);

    XPathExpression xPathExp = xPath.compile(strQuery);


    return (Node) xPathExp.evaluate(domDoc,XPathConstants.NODE);

}

我让文档构建器了解了上下文:

    static DocumentBuilder getDocumentBuilder() {
    DocumentBuilderFactory dbf;
    DocumentBuilder db;

    db = null;

    try {
        dbf = DocumentBuilderFactory.newInstance();
        dbf.setNamespaceAware(true);
        db = dbf.newDocumentBuilder();
    } catch (ParserConfigurationException e) {
        LogMes.log(XMLFactoryServiceImpl.class, LogMes.ERROR, "Erreur lors de la cràation d'un document DOM. Message: " + e.getMessage());
    }
    return db;
}

我在输出=&gt;中得到“使用前缀”这部分好看 我仍然得到一个空值

有什么想法吗?

1 个答案:

答案 0 :(得分:2)

你在99%的路上,你只需要让NamespaceContextxsi前缀返回正确的内容:

    public String getNamespaceURI(String prefix) {

        String uri = null;
        if ("n".equals(prefix)) {
            System.out.println("using prefix");
            uri = nonameNamespace;
        } else if ("xsi".equals(prefix)) {
            uri = "http://www.w3.org/2001/XMLSchema-instance";
        }
        return uri;
    }

此外,如果您通过使用domDoc解析XML来创建DocumentBuilder,则必须通过在docBuilderFactory.setNamespaceAware(true)之前调用.newDocumentBuilder()来确保构建器具有名称空间感知功能。对于我只能假设的历史原因,DBF的默认值是解析而不用处理命名空间,并且这样的DOM树不能用于XPath。