【发布时间】:2011-02-07 13:10:13
【问题描述】:
我正在开发适用于 Android 1.5 的应用程序。目前,我需要解析 XML 文件。由于 Android 在 API 级别 3 中原生不支持 XPath,因此我决定使用 dom4j 和 jaxen 库来读取文件。
我有一个简单的 XML 文件(test1.xml):
<?xml version="1.0" encoding="utf-8" ?>
<tests>
<resources base_lang="en">
<string base="example">
<localization lang="pl">Przykład</localization>
</string>
</resources>
<test name="main name">
<title>Main Title</title>
<description>Long description</description>
</test>
</tests>
还有简单的代码:
SAXReader reader = new SAXReader();
Document doc = reader.read("file:///sdcard/tests/test1.xml");
Node node = doc.selectSingleNode("/tests/test");
Element elem = (Element)node;
for(int j=0;j<elem.attributeCount();++j) {
Attribute attr = elem.attribute(j);
Logger.getLogger(AutoTesterMain.class.getName()).log(Level.SEVERE, "ATTR: "+attr.getName()+"="+attr.getValue());
}
它读取 test1.xml 文件,找到“/tests/test”节点并枚举它的属性。当我将此代码作为“桌面”Java 应用程序的一部分运行时(我不熟悉 Java 术语),它显示了我所期望的(Fedora Linux 下的 OpenJDK 1.8.3):
SEVERE: ATTR: name=main name
不幸的是,在 Android 1.5(模拟器 ofc)中,显示完全相同的代码:
E/AutoTesterMain( 823): ATTR: base_lang=main name
如您所见,属性的值是可以的,但名称有问题。我完全不知道,为什么在这个地方会出现完全来自其他 DOM 元素(“/tests/resources”)的属性名称。它似乎解析我的文件不正确,所以我可能设置错误......
当然,两个版本都使用完全相同的 .jar 和 dom4j 和 jaxen 库,所以这可能没问题。
这个问题的影响不仅仅是不正确的属性列表。它还不允许我使用 XPath 正确读取属性 - 选择 "/tests/test/@name" 没有给出任何结果,而 "/tests/test/@base_lang" 给出了“主名称”字符串。这显然是由与上面列出属性相同的错误引起的。
有人遇到过吗?我该如何解决?
不幸的是,迁移到具有本机 XPath 支持的新 Android 对我来说不是一个选择。
我试图在网上和这里找到任何东西,但没有运气。
【问题讨论】:
标签: java android dom attributes dom4j