使用XmlPullParser解析通道节点

时间:2017-09-17 18:28:41

标签: android rss android-xmlpullparser

我尝试从RSS Feed中解析channel节点,但我一直在parser.nextText()处抛出此错误:

org.xmlpull.v1.XmlPullParserException: precondition: START_TAG (position:END_TAG </link>@3:449 in java.io.InputStreamReader@7988a7d) 

问题似乎是parser.getEventType()是3(END_TAG),应该是2(START_TAG)

  

进给量:

<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" version="2.0">
    <channel>
        <title>Podcast Title</title>
        <link>http://www.link.com</link>
        <description>A description</description>

          <item>
          </item>

          <item>
          </item>

          <item>
          </item>

    </channel>
</rss>

代码:

    XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
    factory.setNamespaceAware(false);
    XmlPullParser parser = factory.newPullParser();
    InputStream stream = new URL(url).openConnection().getInputStream();
    parser.setInput(stream, "UTF-8");
    Boolean inChannel = false;

    int eventType = parser.getEventType();
    while (eventType != XmlPullParser.END_DOCUMENT) {
        String name;
        switch (eventType) {
            case XmlPullParser.START_DOCUMENT:
                break;
            case XmlPullParser.START_TAG:
                name = parser.getName();
                if (name.equalsIgnoreCase("channel"))
                    inChannel = true;
                else if (inChannel)
                {
                    channel = new ChannelItem();
                    if (name.equalsIgnoreCase("description"))
                        channel.setDescription(parser.nextText().trim());
                    else if (name.equalsIgnoreCase("media:thumbnail"))
                        channel.setThumnailUrl(parser.getAttributeValue(null, "url"));
                }
                break;
            case XmlPullParser.END_TAG:
                name = parser.getName();
                if (name.equalsIgnoreCase("channel"))
                    inChannel = false;
                break;
        }
        eventType = parser.next();
    }

2 个答案:

答案 0 :(得分:0)

我放弃了,最后使用了这个:

  final ChannelItem channel = new ChannelItem();

    final RootElement root = new RootElement("rss");
    final Element channelNode = root.getChild("channel");


    channelNode.getChild("title").setEndTextElementListener(new EndTextElementListener()
    {
        public void end(final String body) {
            channel.setTitle(body);
        }
    });

    channelNode.getChild("link").setEndTextElementListener(new EndTextElementListener()
    {
        public void end(final String body) {
            channel.setSiteUrl(body);
        }
    });


    channelNode.getChild("description").setEndTextElementListener(new EndTextElementListener()
    {
        public void end(final String body) {
            channel.setDescription(body);
        }
    });

    try
    {
        InputStream stream = new URL(url).openConnection().getInputStream();

        Xml.parse(stream, Xml.Encoding.UTF_8, root.getContentHandler());
        stream.close();
    }
    catch (Exception e)
    {
    }
    return channel;

答案 1 :(得分:0)

使用Jsoup

解析XML

Xml示例

<?xml version="1.0" encoding="UTF-8">
<tests>
    <test>
        <id>xxx</id>
        <status>xxx</status>
    </test>
    <test>
        <id>xxx</id>
        <status>xxx</status>
    </test>
    ....
</tests>

代码示例

String html = "<?xml version=\"1.0\" encoding=\"UTF-8\"><tests><test><id>xxx</id><status>xxx</status></test><test><id>xxx</id><status>xxx</status></test></tests></xml>";
Document doc = Jsoup.parse(html, "", Parser.xmlParser())
for (Element e : doc.select("test")) {
    System.out.println(e);
}