我正在编写一个Android应用程序,我想从web获取一个xml字符串并获取它包含的所有信息。 首先,我得到字符串(此代码有效):
URL url = new URL("here my adrress");
BufferedReader reader = new BufferedReader(new InputStreamReader(url.openStream()));
String myData = reader.readLine();
reader.close();
然后,我使用DOM:
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
InputSource is = new InputSource();
is.setCharacterStream(new StringReader(myData));
仍然没问题。我写的时候
Document doc = db.parse(is);
应用程序不再执行任何操作。它停止,没有错误。 有人可以告诉我发生了什么事吗?
答案 0 :(得分:4)
我不知道为什么你的代码不起作用,因为没有错误,但我可以提供替代方案。
首先,我很确定你的新InputStream“是”是不必要的。 “parse()”可以直接将“url.openStream()”或“myData”作为参数。
错误的另一个原因可能是你的xml数据有多行(我知道你说你的代码的第一部分工作但是我更愿意提及它,只是为了确定)。如果是这样,“reader.readLine()”只会为您提供xml数据的一部分。
我希望这会有所帮助。
答案 1 :(得分:1)
使用SAXParser而不是DOM解析器。 SAXParser比DOM解析器更有效。这是关于SAXParser的两个很好的教程 1. http://www.androidpeople.com/android-xml-parsing-tutorial-using-saxparser 2. http://www.anddev.org/parsing_xml_from_the_net_-_using_the_saxparser-t353.html
答案 2 :(得分:1)
使用XmlPullParser
,速度非常快。从Web传入字符串并获取包含所有值的哈希表。
public Hashtable<String, String> parse(String myData) {
XmlPullParser parser = Xml.newPullParser();
Hashtable<String, String> responseFromServer = new Hashtable<String, String>();
try {
parser.setInput(new StringReader (responseString));
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
if(eventType == XmlPullParser.START_TAG) {
String currentName = parser.getName();
String currentText = parser.nextText();
if (currentText.trim().length() > 0) {
responseFromServer.put(currentName, currentText);
}
}
eventType = parser.next();
}
} catch (Exception e) {
e.printStackTrace();
}
return responseFromServer;
}