我正在尝试使用Apache Digester从一些XML中使用一个字符串列表,如FAQ中的How do I add literal elements to a List object?部分所述。
我遇到以下错误:
[DEBUG] Digester - [SetNextRule]{job/editorial/articlegroup/article} Call java.util.ArrayList.setFields([This, This, is, is, a, a, test, test, , , , ])
[ERROR] Digester - End event threw exception <java.lang.NoSuchMethodException: No such accessible method: setFields() on object: java.util.ArrayList>java.lang.NoSuchMethodException: No such accessible method: setFields() on object: java.util.ArrayList
我正在使用的XML的简化版本如下:
<job>
<editorial>
<articlegroup>
<article>
<text>
<content><![CDATA[This]]></content>
</text>
<text>
<content><![CDATA[is]]></content>
</text>
<text>
<content><![CDATA[a]]></content>
</text>
<text>
<content><![CDATA[test]]></content>
</text>
</article>
</articlegroup>
</editorial>
</job>
源代码:
public class PPJob {
List<String> fields;
public List<String> getFields() {
return fields;
}
public void setFields(List<String> fields) {
this.fields = fields;
}
}
addObjectCreate("job", PPJob.class);
addSetProperties("job");
addObjectCreate("job/editorial/articlegroup/article", ArrayList.class);
addCallMethod("job/editorial/articlegroup/article/text/content", "add", 1);
addCallParam("job/editorial/articlegroup/article/text/content", 0);
addSetNext("job/editorial/articlegroup/article", "setFields");
PPJob result = (PPJob)super.parse([THE XML]);
我几乎是使用Digester的新手,而且我很难跟踪我需要的示例。
谁能看到我出错的地方?
答案 0 :(得分:1)
嗯,这个问题为我赢得了“Tumbleweed”徽章,我很难找到一些方法来重新解决这个问题,因此更容易理解。所以这是我的进展的最新消息:
我最终决定放弃Commons Digester,时间限制使得很难进一步追查这个问题,因此我没有在Digester项目中记录错误(如果其他人让我知道并且我会分享我的经验)。
javax XPath函数证明更符合我的要求,我决定使用这个解决方案:
XPathFactory factory = XPathFactory.newInstance();
XPath xPath = factory.newXPath();
rootQuery = xPath.compile("/job");
textFieldsQuery = xPath.compile("/job/editorial/articlegroup/article/text|/job/editorial/articlegroup/article/flashtext");
Node rootNode = (Node)rootQuery.evaluate(new InputSource(is), XPathConstants.NODE);
PPJob job = new PPJob();
Map<String, String> jobTextFields = new HashMap<String, String>();
NodeList fields = (NodeList)query.evaluate(rootNode, XPathConstants.NODESET);
for (int i = 0; i < fields.getLength(); i++) {
Node field = fields.item(i);
String fieldName = field.getAttributes().getNamedItem("name").getNodeValue();
String fieldContent = field.getNextSibling().getNodeValue();
jobTextFields.put(fieldName, fieldContent);
}
job.setTextFields(jobTextFields);
如果有人对这个问题有任何建议,我仍然有兴趣听到为什么我对Digester这么麻烦。