2013-03-28 3 views
0

Так что я думаю, что задавал неправильный ответ в предыдущих потоках. Я бы сказал так. Я пытаюсь разобрать данные XML:XML Parser Возвращение неожиданной ошибки маркера и исключения нулевого указателя

<playlist> 
<title>![CDATA[New Playlist]]</title> 
<items> 
<item> 
<title>HAMD(LA ILAHA ILLALLAH)</title> 
<description>Recited By :Alhaaj Muhammad Owais Raza Qadri -- Written By: Mufti-e-Azam Hind Molana Mustafa Raza Khan Noori</description> 
<image>http://xxx.xxx.xxx.xxx/~kanz/video/Images/9.jpg</image> 
<startFromThis>true</startFromThis> 
<duration>510</duration> 
<source>http://xxx.xxx.xxx.xxx/~kanz/video/flv/9.flv</source> 
<sourceAlt>http://xxx.xxx.xxx.xxx/~kanz/video/mp4/9.mp4</sourceAlt> 
<sourceType>direct</sourceType> 
</item> 
</items> 
</playlist> 

В моей деятельности, что я сделал это, но LogCat дает исключения нулевого указателя. Вот моя активность, а ниже - ошибка logcat.

static final String URL = "http://xxx.xxx.xxx.xxx/~kanz/video/XML/9.xml"; 

// XML node keyse. 
static final String KEY_SONG = "item"; // parent node 
static final String KEY_TITLE = "title"; 
static final String KEY_ARTIST = "description"; 
static final String KEY_THUMB_URL = "image"; 
static final String KEY_DURATION = "duration"; 

NodeList nl = doc.getElementsByTagName(KEY_SONG); 

// looping through all song nodes <song> 
for (int i = 0; i < nl.getLength(); i++) { 
    // creating new HashMap 
    HashMap<String, String> map = new HashMap <String, String>(); 
    Element e = (Element) nl.item(i); 
    // adding each child node to HashMap key => value 
    map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE)); 
    map.put(KEY_ARTIST, parser.getValue(e, KEY_ARTIST)); 
    map.put(KEY_THUMB_URL, parser.getValue(e, KEY_THUMB_URL)); 
    map.put(KEY_DURATION, parser.getValue(e, KEY_DURATION)); 

    // adding HashList to ArrayList 
    songsList.add(map); 
} 

Logcat дает Неожиданную ошибку Token и возвращает значение null, которое вызывает исключение нулевого указателя.

03-28 14:31:34.059: E/Error:(895): Unexpected token (position:TEXT @1:4 in [email protected]) 
03-28 14:31:34.080: I/System.out(895): null 
03-28 14:42:59.560: D/AndroidRuntime(978): Shutting down VM 
03-28 14:42:59.560: W/dalvikvm(978): threadid=1: thread exiting with uncaught exception (group=0x40a71930) 
03-28 14:42:59.639: E/AndroidRuntime(978): FATAL EXCEPTION: main 
03-28 14:42:59.639: E/AndroidRuntime(978): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.razatubevidurl/com.example.razatubevidurl.CustomizedListView}: java.lang.NullPointerException 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.app.ActivityThread.access$600(ActivityThread.java:141) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.os.Handler.dispatchMessage(Handler.java:99) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.os.Looper.loop(Looper.java:137) 
03-28 14:42:59.639: E/AndroidRuntime(978): at android.app.ActivityThread.main(ActivityThread.java:5041) 
03-28 14:42:59.639: E/AndroidRuntime(978): at java.lang.reflect.Method.invokeNative(Native Method) 
03-28 14:42:59.639: E/AndroidRuntime(978): at java.lang.reflect.Method.invoke(Method.java:511) 
03-28 14:42:59.639: E/AndroidRuntime(978): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
03-28 14:42:59.639: E/AndroidRuntime(978): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
03-28 14:42:59.639: E/AndroidRuntime(978): at dalvik.system.NativeStart.main(Native Method) 
03-28 14:42:59.639: E/AndroidRuntime(978): Caused by: java.lang.NullPointerException 

Пожалуйста, расскажите мне, что я делаю неправильно. Я думал, что мой предыдущий вопрос был расплывчатым, и в этом я попытался изо всех сил сделать этот вопрос ясным и понятным.

+0

где вы выбираете xml-контент? – Sajmon

+0

@Sajmon Из URL-адреса, инициализированного URL-адресом переменной. –

ответ

0

Я думаю, что это что-то кодирование. Возможно, вашему парсеру не нравится восклицательный знак (!). Можете ли вы убедиться, что используете XML-файл с правильной кодировкой? (UTF-8)

В противном случае у вас есть эта проблема: KXmlParser throws "Unexpected token" exception at the start of RSS pasing.

Я googled вокруг, и это выглядит как самое простое исправление here. Вы можете попробовать добавить этот метод. (Из учебника вы используете, поместите это в классе ImageLoader.)

import java.io.PushbackInputStream; 
private InputStream checkForUtf8BOMAndDiscardIfAny(InputStream inputStream) throws IOException { 
PushbackInputStream pushbackInputStream = new PushbackInputStream(new BufferedInputStream(inputStream), 3); 
byte[] bom = new byte[3]; 
if (pushbackInputStream.read(bom) != -1) { 
    if (!(bom[0] == (byte) 0xEF && bom[1] == (byte) 0xBB && bom[2] == (byte) 0xBF)) { 
     pushbackInputStream.unread(bom); 
    } 
} 
return pushbackInputStream; } 

Затем вы можете сделать

InputStream is=conn.getInputStream(); 
is = checkForUtf8BOMAndDiscardIfAny(is); 

У меня нет возможности проверить метод, но он должен сделать это. Также см. Byte order mark screws up file reading in Java.

+0

да XML кодируется в кодировке UTF-8. –

+0

ли ссылка, которую вы отправили в ответе, анализирует XML с сервера? Потому что моя хранится на сервере. –

+0

Да, он отправляется с сервера. Вы можете попробовать создать новый локальный XML-файл с тем же содержимым и проанализировать его. – pt2121

Смежные вопросы