在Digester中定位特定属性 - Java

时间:2010-12-05 07:26:10

标签: java xml apache-commons-digester

我正在使用Apache Commons Digester并尝试在结构中找到要包含在对象中的特定标记。

  

<parent>

     

<image size="small">some url</image>

     

<image size="medium">some url</image>

     

<image size="large">some url</image>

     

<image size="huge">some url</image>

     

</parent>

我真的只想将medium图像包含在我的partent对象中,但我不确定如何做到这一点。

现在我正在使用digester.addBeanPropertySetter(PathToParent+"/image","image");但是这会针对每个image标记进行更新(应该如此)。

理想情况下,我希望digester.addBeanPropertySetter(PathToParent+"/image/medium","image");之类的东西,但你不能这样做。

3 个答案:

答案 0 :(得分:2)

我省略了通用的getter / setter。

  public class Parent {

    private Image image;

    public void setImage(Image image) {
      if ("medium".equals(image.getSize())) {
        this.image = image;
      }
    }

  }

  public class Image {

    private String size;
    private String url;
  }

  public static void main(String[] args) throws IOException, SAXException {
    String s = "<parent>" 
        + "<image size='small'>some url1</image>"
        + "<image size='medium'>some url2</image>"
        + "<image size='large'>some url3</image>"
        + "<image size='huge'>some url4</image>"
        + "</parent>";

    Digester digester = new Digester();

    digester.addObjectCreate("parent", Parent.class);
    digester.addFactoryCreate("parent/image", new ImageCreationFactory());
    digester.addBeanPropertySetter("parent/image", "url");
    digester.addSetNext("parent/image", "setImage");
    Parent p = (Parent) digester.parse(new StringReader(s));
  }

  public class ImageCreationFactory implements ObjectCreationFactory {

    public Object createObject(Attributes attributes) throws Exception {
      Image i = new Image();
      i.setSize(attributes.getValue("size"));
      return i;
    }

  }

答案 1 :(得分:1)

我实际上是使用xmlpullparser来解决这个问题 - 这里只是获取图像属性“大”的代码而忽略其余的 - 它是case语句中的最后一个“if”。

公共类XmlPullFeedParser扩展了BaseFeedParser {

public XmlPullFeedParser(String feedUrl) {
    super(feedUrl);
}

public ArrayList<Message> parse() {
    ArrayList<Message> messages = null;
    XmlPullParser parser = Xml.newPullParser();
    try {
        // auto-detect the encoding from the stream
        parser.setInput(this.getInputStream(), null);
        int eventType = parser.getEventType();
        Message currentMessage = null;
        boolean done = false;
        while (eventType != XmlPullParser.END_DOCUMENT && !done){
            String name = null;
            String attrib = null;
            switch (eventType){
                case XmlPullParser.START_DOCUMENT:
                    messages = new ArrayList<Message>();
                    break;
                case XmlPullParser.START_TAG:
                    name = parser.getName();
                    attrib = parser.getAttributeValue(0);
                    if (name.equalsIgnoreCase(EVENT)){
                        currentMessage = new Message();
                    } else if (currentMessage != null){
                        if (name.equalsIgnoreCase(WEBSITE)){
                            currentMessage.setWebsite(parser.nextText());
                        } else if (name.equalsIgnoreCase(DESCRIPTION)){
                            currentMessage.setDescription(parser.nextText());
                        } else if (name.equalsIgnoreCase(START_DATE)){
                            currentMessage.setDate(parser.nextText());
                        } else if (name.equalsIgnoreCase(TITLE)){
                            currentMessage.setTitle(parser.nextText());
                        } else if (name.equalsIgnoreCase(HEADLINER)){
                            currentMessage.setHeadliner(parser.nextText());
                        } else if ((name.equalsIgnoreCase(IMAGE)) && (attrib.equalsIgnoreCase("large"))) {
                            currentMessage.setImage(parser.nextText());
                        }   
                    }
                    break;
                case XmlPullParser.END_TAG:
                    name = parser.getName();
                    if (name.equalsIgnoreCase(EVENT) && currentMessage != null){
                        messages.add(currentMessage);
                    } else if (name.equalsIgnoreCase(EVENTS)){
                        done = true;
                    }
                    break;
            }
            eventType = parser.next();
        }
    } catch (Exception e) {
        Log.e("AndroidNews::PullFeedParser", e.getMessage(), e);
        throw new RuntimeException(e);
    }
    return messages;
}

}

答案 2 :(得分:0)

我不认为这是可能的。您必须编写自己的代码来执行此类过滤。

但这很简单。如果您希望使用方法getImage(String size)创建名为ImageAccessor的干净代码编写类。此方法将从蒸煮器获取数据,并将其与预定义的大小字符串(或模式)进行比较。