应用程序在getElementsByTagName崩溃

时间:2012-06-28 16:36:12

标签: java android xml

我想从我的应用程序的网络收音机中读取.xml文件。

我使用过本教程:http://www.androidhive.info/2011/11/android-xml-parsing-tutorial/

这是功能:

public String leggi_palinsesto(){
    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL); // getting XML
    Document doc = parser.getDomElement(xml); // getting DOM element

    NodeList nl = doc.getElementsByTagName(KEY_ITEM);

    // looping through all item nodes <item>
    for (int i = 0; i < 1; i++) {
        Element e = null;
        String titolo = parser.getValue(e, KEY_TITOLO); // name child value
        String artista = parser.getValue(e, KEY_ARTISTA); // cost child value

        System.out.println(artista+" - "+titolo);
    }

    return titolo+" "+artista;
}

但是当到达NodeList nl = doc.getElementsByTagName(KEY_ITEM);应用程序崩溃时。

这是logcat:

06-28 18:27:58.089: E/AndroidRuntime(1050): FATAL EXCEPTION: main
06-28 18:27:58.089: E/AndroidRuntime(1050): java.lang.NullPointerException
06-28 18:27:58.089: E/AndroidRuntime(1050):     at it.axiomatic.radioamicizia.RadioAmiciziaActivity.leggi_palinsesto(RadioAmiciziaActivity.java:315)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at it.axiomatic.radioamicizia.RadioAmiciziaActivity$1$1.run(RadioAmiciziaActivity.java:122)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at android.os.Handler.handleCallback(Handler.java:587)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at android.os.Handler.dispatchMessage(Handler.java:92)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at android.os.Looper.loop(Looper.java:123)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at android.app.ActivityThread.main(ActivityThread.java:4627)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at java.lang.reflect.Method.invokeNative(Native Method)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at java.lang.reflect.Method.invoke(Method.java:521)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
06-28 18:27:58.089: E/AndroidRuntime(1050):     at dalvik.system.NativeStart.main(Native Method)

这是常数:

static final String URL = "http://www.radioamicizia.com/demo.xml";
    // XML node keys
    static final String KEY_ITEM = "song"; // parent node
    static final String KEY_TITOLO = "Title";
    static final String KEY_ARTISTA = "Artist";

有人可以帮我解决这个问题。

2 个答案:

答案 0 :(得分:0)

doc变量为null,因此尝试在其上调用getElementByTagName会抛出NPE。

它来自parser.getDomElement(xml)或之前。

简而言之,请确保您完整地遵循了教程,并且您的XmlParser类与教程完全相同,并且方法不会返回null。

另外,学会将调试器附加到您的进程,设置断点,并以这种方式检查您的代码,我建议您使用Intellij社区版,这很容易。 :)

答案 1 :(得分:0)

我建议在AsyncTask内下载XML文件。通常,您希望从主UI线程中获取网络操作。

由于您收到NullPointerExceptionString xml可能无法从您的网站获取任何数据,然后您尝试将该空字符串传递给XML解析器而不检查输入。

所以,我建议您阅读:http://developer.android.com/reference/android/os/AsyncTask.html

然后在解析它之前检查你的String是否为null:

if (xml!= null && !xml.isEmpty()) {
    Document doc = parser.getDomElement(xml); // getting DOM element
    NodeList nl = doc.getElementsByTagName(KEY_ITEM);
    ...
}