如果你用XmlPullParser来解析下面这段XML片段的话,那么就要注意了:
<content type="xhtml">
<div xmlns="http://www.w3.org/1999/xhtml">
<p>This is the entry content.</p>
</div>
</content>
当你调用nextText时候,在低版本会有一个Bug,在Android4.0之后修复了这个Bug,所以可以在API说明上看到:
如果在解析到<content type="xhtml">后使用nextText方法,此方法会读取到<div xmlns="http://www.w3.org/1999/xhtml">这个开始标签而抛出XmlPullParserException异常。
解决方法在先调用nextText再调用nextTag,如下方法:
public static String safeNextText(XmlPullParser parser) {
String result = null;
try {
result = parser.nextText();
if (parser.getEventType() != XmlPullParser.END_TAG) {
parser.nextTag();
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
但视乎这样只能获取到空的节点内容,目前还没有比较通用的方法获取其中的内容。。。希望知道的告知下。
声明
原创文章,欢迎转载,请保留出处。
有任何错误、疑问或者建议,欢迎指出。
我的邮箱:Maxwell_nc@163.com
本文探讨了使用XmlPullParser解析特定XML片段时遇到的Bug及其解决方法,包括如何避免在Android4.0之后版本中出现的问题,并提供了一个自定义方法用于安全地获取XML内容。同时,文章还分享了获取XML片段中内容的通用方法,以及原创文章的声明。
306

被折叠的 条评论
为什么被折叠?



