public String getXmlFromUrl(String url) {
String xml = null;
try {
// defaultHttpClient
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url);
HttpResponse httpResponse = httpClient.execute(httpPost);
HttpEntity httpEntity = httpResponse.getEntity();
xml = EntityUtils.toString(httpEntity);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
// return XML
return xml;
}
获取 XML 内容后,我们需要获取 XML 文件的 DOM 元素。下面的函数将解析 XML 内容并为您提供 DOM 元素。
public Document getDomElement(String xml){
Document doc = null;
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder db = dbf.newDocumentBuilder();
InputSource is = new InputSource();
is.setCharacterStream(new StringReader(xml));
doc = db.parse(is);
} catch (ParserConfigurationException e) {
Log.e("Error: ", e.getMessage());
return null;
} catch (SAXException e) {
Log.e("Error: ", e.getMessage());
return null;
} catch (IOException e) {
Log.e("Error: ", e.getMessage());
return null;
}
// return DOM
return doc;
}
通过传递元素节点名称获取每个xml子元素值
static final String KEY_ITEM = "URL"; // parent node
XMLParser parser = new XMLParser();
String xml = parser.getXmlFromUrl(URL); // getting XML
Document doc = parser.getDomElement(xml); // getting DOM element
NodeList nl = doc.getElementsByTagName(rootitem);
// looping through all item nodes <item>
for (int i = 0; i < nl.getLength(); i++) {
Node node = nl.item(i);
Element e = (Element) node;
NodeList tag = e.getElementsByTagName("url");
Element element = (Element) tag.item(0);
tag = element.getChildNodes();` // name child value
String value = ((Node) categoryList.item(0)).getNodeValue().toString();