xmlPull解析网络数据(xml文件)

来源:互联网 发布:js下一个兄弟节点 编辑:程序博客网 时间:2024/06/11 06:31

private void getXml() {
new Thread() {
public void run() {
try {
ListItem news = null;
URL url = new URL(path);
HttpURLConnection connection = (HttpURLConnection) url
.openConnection();
connection.setReadTimeout(5000);
connection.setRequestMethod(“GET”);
connection.setConnectTimeout(5000);
InputStream inputStream = connection.getInputStream();
XmlPullParserFactory factory = XmlPullParserFactory
.newInstance();
XmlPullParser parser = factory.newPullParser();
parser.setInput(inputStream, “utf-8”);
int type_name = parser.getEventType();
System.out.println(“开始解析”);
while (parser.getEventType() != XmlPullParser.END_DOCUMENT) {
switch (type_name) {
case XmlPullParser.START_DOCUMENT:
list = new ArrayList();
break;
case XmlPullParser.START_TAG:
if (“news”.equals(parser.getName())) {
news = new ListItem();
}
if (news != null) {
if (“id”.equals(parser.getName())) {
news.id = parser.nextText();
} else if (“title”.equals(parser.getName())) {
news.title = parser.nextText();
} else if (“body”.equals(parser.getName())) {
news.body = parser.nextText();
} else if (“commentCount”.equals(parser
.getName())) {
news.commentCount = parser.nextText();
} else if (“author”.equals(parser.getName())) {
news.author = parser.nextText();
} else if (“authorid”.equals(parser.getName())) {
news.authorid = parser.nextText();
} else if (“pubDate”.equals(parser.getName())) {
news.pubDate = parser.nextText();
} else if (“url”.equals(parser.getName())) {
news.url = parser.nextText();
}
}
break;
case XmlPullParser.END_TAG:
if (news != null) {
list.add(news);
}
break;

                    default:                        break;                    }                    type_name = parser.next();                }                handler.sendEmptyMessage(0x123);            } catch (Exception e) {                e.printStackTrace();            }        };    }.start();
0 0