“没有这样的可访问方法:对象上的setFields():java.util.ArrayList”使用Apache Digester时

时间:2010-07-08 16:34:04

标签: java apache-commons-digester

我正在尝试使用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的新手,而且我很难跟踪我需要的示例。

谁能看到我出错的地方?

1 个答案:

答案 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这么麻烦。