有没有办法获取 XML 文档中使用的前缀/命名空间绑定(bind),最好使用标准 org.w3c.org
和javax.xml
蜜蜂?据我所知,前缀可能会在包含的元素中重新定义,因此 API 也应该能够考虑到这一点。
我正在寻找一个代码片段,它将采用某种序列化形式的 XML 文档并返回 Map<String, String>
URI 名称绑定(bind)的前缀(加上 API 中的一些额外的聪明来考虑封闭元素中的重新定义)。理想情况下,库可能能够做一些更奇特的事情,例如识别/清除未使用的绑定(bind),将重复的绑定(bind)移动到最近的共同祖先(而不是让它们到处复制)等等。
最佳答案
这是一个开始,使用 Guava MultiMap :
Document doc = ...;
Multimap<String, String> bindings = LinkedHashMultimap.create();
DocumentTraversal dt = (DocumentTraversal) doc;
NodeIterator i = dt.createNodeIterator(doc, NodeFilter.SHOW_ELEMENT,
null, false);
Element element = (Element) i.nextNode();
while (element != null) {
String prefix = element.getPrefix();
if (prefix != null) {
String uri = element.getNamespaceURI();
bindings.put(prefix, uri);
}
element = (Element) i.nextNode();
}
这只会获取有效的绑定(bind),并且不会绑定(bind)任何默认 namespace (当然可以修复)。绑定(bind)的重新定义将按文档顺序表示,而不是它们发生的深度。
我想此方法的任何进一步改进取决于您的用例,例如您还需要哪些信息来使重新定义的绑定(bind)变得有意义?
关于java - 获取 XML 文档中使用的前缀/命名空间绑定(bind),最好使用 org.w3c.dom 和 javax.xml API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18382375/