我一直在试图弄清楚如何解决我在尝试解析 XML 文件时收到的错误。
这是我的 MainActivity.java 文件:
package com.example.android;
import java.io.IOException;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xmlpull.v1.XmlPullParser;
import android.R.string;
import android.app.Activity;
import android.os.Bundle;
import android.renderscript.Element;
import android.util.Log;
import android.view.Menu;
import android.view.Window;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.TextView;
public class MainActivity extends Activity {
String playerId,
playerPd,
playerType,
xml;
DefaultHttpClient httpClient;
HttpPost httpPost;
HttpResponse httpResponse;
HttpEntity httpEntity;
Document doc;
DocumentBuilderFactory dbf;
DocumentBuilder db;
InputSource inputSource;
NodeList n,
nl;
Node child;
XmlPullParser parser;
static final String URL = ".xml URL WITHELD";
static final String PLAYERS = "Players"; //parent node
static final String PLAYER_PD = "PlayerPD";
static final String PLAYER_TYPE = "PlayerType";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//Remove title bar
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
public String getXmlFromUrl(String url){
xml = null;
try{
//defaultHttpClient
httpClient = new DefaultHttpClient();
httpPost = new HttpPost (url);
httpResponse = httpClient.execute(httpPost);
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;
}
public Document getDomElement(String xml){
doc = null;
dbf = DocumentBuilderFactory.newInstance();
try{
db = dbf.newDocumentBuilder();
inputSource = new InputSource();
inputSource.setCharacterStream(new StringReader (xml));
doc = db.parse(inputSource);
} 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;
}
public String getValue(Element item, String str){
n = ((Document) item).getElementsByTagName(str);
return this.getElementValue(n.item(0));
}
private final String getElementValue(Node elem){
// TODO Auto-generated method stub
if(elem.hasChildNodes()){
for(child = elem.getFirstChild(); child != null; child = child.getNextSibling()){
if(child.getNodeType() == Node.TEXT_NODE){
return child.getNodeValue();
}
}
}
return null;
}
public void parseXml(){
xml = parser.getXmlFromUrl(URL); //Getting XML
在这一行,第 149 行,我收到一条错误消息:“方法 getXmlFromUrl(String) 未定义用于 XmlPullParser 类型”
doc = parser.getDomElement(xml); //Getting DOM element
而且,在这一行,第 150 行,我收到一条错误消息:“方法 getDomElement(String) 未定义 XmlPullParser 类型”
nl = doc.getElementsByTagName(PLAYERS);
for (int i = 0; i < nl.getLength(); i++){
playerPd = parser.getValue(e, PLAYER_PD); //PlayerPD child value
此外,在这一行及其后的行 155 和 156 上,我收到一条错误消息,提示“e 无法解析为变量”
playerType = parser.getValue(e, PLAYER_TYPE); //Player Type child value
}
}
}
如果这有帮助,我试图解析的 XML 文件的布局是这样的:
-<Players>
-<Player id="">
<PlayerType></PlayerType>
</Player>
</Players>
任何帮助将不胜感激,并在此先感谢。