Update:-看来我必须提供返回 xml 的 URL。这里是 -URL
解析 xml 时出现 SAXParseException。我试图解析的 xml 如下 -
<?xml version="1.0" encoding="utf-8"?>
<markers xmlns="">
<marker name="" address1="" address2="" region="" country="" zip="" imgsrc="" lat="" lng="" distance="" />
<marker name="" address1="" address2="" region="" country="" zip="" imgsrc="" lat="" lng="" distance="" />
<marker name="" address1="" address2="" region="" country="" zip="" imgsrc="" lat="" lng="" distance="" />
<marker name="" address1="" address2="" region="" country="" zip="" imgsrc="" lat="" lng="" distance="" />
<marker name="" address1="" address2="" region="" country="" zip="" imgsrc="" lat="" lng="" distance="" />
</markers>
我用来解析这个 xml 的代码如下 -
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) {
e.printStackTrace();
Log.e("ParserConfigurationException: ", e.getMessage());
return null;
} catch (SAXException e) {
e.printStackTrace();
Log.e("SAXException: ", e.getMessage());
return null;
} catch (IOException e) {
e.printStackTrace();
Log.e("IOException: ", e.getMessage());
return null;
}
return doc;
}
我使用相同的代码来解析其他 xml 数据并且它有效。我无法理解这个 xml 数据中有什么阻止它正确解析数据。我也用许多在线 xml 验证器检查了 xml。
我一定在这里遗漏了一些明显的东西。
EDIT:-我试图解析的 xml 来自网络服务(名称、地址等实际上不是空的)。当我尝试通过在代码本身中进行硬编码来直接使用 xml 时,它工作得很好。但是当尝试直接从网络服务响应使用它时,对我来说不起作用。
例外:-
10-09 20:39:50.328: W/System.err(16211): org.xml.sax.SAXParseException: Unexpected token (position:TEXT @1:2 in java.io.StringReader@41941010)
10-09 20:39:50.335: W/System.err(16211): at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:146)
10-09 20:39:50.335: W/System.err(16211): at com.blackcobrastudios.ukash.WebService.XMLDataParser.getDomElement(XMLDataParser.java:159)
10-09 20:39:50.335: W/System.err(16211): at com.blackcobrastudios.ukash.Manager.APICaller.processResult(APICaller.java:386)
10-09 20:39:50.335: W/System.err(16211): at com.blackcobrastudios.ukash.Manager.APICaller.access$1(APICaller.java:385)
10-09 20:39:50.335: W/System.err(16211): at com.blackcobrastudios.ukash.Manager.APICaller$SoapCaller.onPostExecute(APICaller.java:361)
10-09 20:39:50.335: W/System.err(16211): at com.blackcobrastudios.ukash.Manager.APICaller$SoapCaller.onPostExecute(APICaller.java:1)
10-09 20:39:50.335: W/System.err(16211): at android.os.AsyncTask.finish(AsyncTask.java:602)
10-09 20:39:50.343: W/System.err(16211): at android.os.AsyncTask.access$600(AsyncTask.java:156)
10-09 20:39:50.343: W/System.err(16211): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:615)
10-09 20:39:50.343: W/System.err(16211): at android.os.Handler.dispatchMessage(Handler.java:99)
10-09 20:39:50.343: W/System.err(16211): at android.os.Looper.loop(Looper.java:137)
10-09 20:39:50.343: W/System.err(16211): at android.app.ActivityThread.main(ActivityThread.java:4536)
10-09 20:39:50.343: W/System.err(16211): at java.lang.reflect.Method.invokeNative(Native Method)
10-09 20:39:50.351: W/System.err(16211): at java.lang.reflect.Method.invoke(Method.java:511)
10-09 20:39:50.351: W/System.err(16211): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
10-09 20:39:50.351: W/System.err(16211): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:558)
10-09 20:39:50.351: W/System.err(16211): at dalvik.system.NativeStart.main(Native Method)
10-09 20:39:50.351: E/SAXException:(16211): Unexpected token (position:TEXT @1:2 in java.io.StringReader@41941010)