Не удается разобрать JSON в ListView


То, что я пытаюсь


Я хотел бы понять JSON на глубоком уровне. Для этого я, правда, создаю приложение для своего Youtube-канала. Сначала я создал JSON-файл своего канала на этом сайте: GData Youtube и создал этот JSON-файл: JSON канала .

После этого я начал создавать свое Channel-приложение с этим учебником: JSON Tutorial , я немного изменил его, чтобы он" должен " работать с моим Channel-JSON-файлом, но он просто не работает и Я действительно не понимаю, почему, это сообщение об ошибке, которое я всегда получаю. 11-22 08:35:37.932: E/CANT READ DATA(15923): Error parsing data org.json.JSONException: Value Response of type java.lang.String cannot be converted to JSONObject

Дело в коде функции JSON.java работает на учебнике, и здесь это не так, поэтому что-то должно быть не так в основном.- но я не понимаю, что такое ложь.!!! : (

Вопрос


Что мне нужно изменить в моем основном.java, чтобы заставить мой код работать. Если у вас есть учебник по проблеме, которую я получил, или действительно хороший пример кода, я тоже буду рад. Вот как выглядит JSON-файл из Канал выглядит следующим образом: JSON-структура Код и журнал ошибок вы найдете здесь:

Код


JSONfunction.java

package de.stepforward;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.HashMap;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.util.Log;

public class JSONfunction {

    public static JSONObject getJSONfromURL(String url){
        InputStream is = null;
        String result = "";
        JSONObject jArray = null;

        //http post
        try{
                HttpClient httpclient = new DefaultHttpClient();
                HttpPost httppost = new HttpPost(url);
                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();
                is = entity.getContent();

        }catch(Exception e){
                Log.e("NO CONNECTION", "Error in http connection "+e.toString());
        }

      //convert response to string
        try{
                BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
                StringBuilder sb = new StringBuilder();
                String line = null;
                while ((line = reader.readLine()) != null) {
                        sb.append(line + "n");
                }
                is.close();
                result=sb.toString();
        }catch(Exception e){
                Log.e("CANT CONVERT DATA", "Error converting result "+e.toString());
        }

        try{

            jArray = new JSONObject(result);            
        }catch(JSONException e){
                Log.e("CANT READ DATA", "Error parsing data "+e.toString());
        }

        return jArray;
    }
}

ShowChannel.java

    package de.stepforward;

import java.util.ArrayList;
import java.util.HashMap;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.ListActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;


public class ShowChannel  extends ListActivity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>();

        JSONObject json = JSONfunction.getJSONfromURL("http://gdata.youtube.com/feeds/mobile/users/TheStepForward/uploads?alt=json&format=1");

        try{
        JSONObject feed = json.getJSONObject("feed");   
        JSONArray entry = feed.getJSONArray("entry");

        for(int i=0;i<entry.length();i++){                      
            HashMap<String, String> map = new HashMap<String, String>();    
            JSONObject e = entry.getJSONObject(i);

            map.put("title", e.getString("title.$t"));
            map.put("description", e.getString("content.$t"));
            map.put("link", e.getString("media$player"));
            map.put("thumbnail", e.getString("media$thumbnail.url"));
            mylist.add(map);

        }



        }catch(JSONException e)        {
         Log.e("log_tag", "Error parsing data "+e.toString());
       }

        //Liste füllen
        ListAdapter adapter = new SimpleAdapter(this, mylist , R.layout.listlayout, 
                new String[] {"thumbnail", "title", "description", "link" }, 
                new int[] { R.id.img_video, R.id.txt_title, R.id.txt_subtitle });

        setListAdapter(adapter);

        //OnItemClickListner für Hyperlinks
        final ListView lv = getListView();
        lv.setTextFilterEnabled(true);  
        lv.setOnItemClickListener(new OnItemClickListener() {
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {   
                @SuppressWarnings("unchecked")
                HashMap<String, String> o = (HashMap<String, String>) lv.getItemAtPosition(position);
                Toast.makeText(ShowChannel.this, "Link '" + o.get("link") + "' was clicked.", Toast.LENGTH_SHORT).show();
            }

        });

    }

}

Журнал Ошибок

11-22 08:35:37.932: E/CANT READ DATA(15923): Error parsing data org.json.JSONException: Value Response of type java.lang.String cannot be converted to JSONObject
11-22 08:35:37.932: D/AndroidRuntime(15923): Shutting down VM
11-22 08:35:37.932: W/dalvikvm(15923): threadid=1: thread exiting with uncaught exception (group=0x4001d5a0)
11-22 08:35:38.032: E/AndroidRuntime(15923): FATAL EXCEPTION: main
11-22 08:35:38.032: E/AndroidRuntime(15923): java.lang.RuntimeException: Unable to start activity ComponentInfo{de.stepforward/de.stepforward.ShowChannel}: java.lang.NullPointerException
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1816)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1837)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread.access$1500(ActivityThread.java:132)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1033)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.os.Handler.dispatchMessage(Handler.java:99)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.os.Looper.loop(Looper.java:143)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread.main(ActivityThread.java:4196)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at java.lang.reflect.Method.invokeNative(Native Method)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at java.lang.reflect.Method.invoke(Method.java:507)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at dalvik.system.NativeStart.main(Native Method)
11-22 08:35:38.032: E/AndroidRuntime(15923): Caused by: java.lang.NullPointerException
11-22 08:35:38.032: E/AndroidRuntime(15923):    at de.stepforward.ShowChannel.onCreate(ShowChannel.java:36)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
11-22 08:35:38.032: E/AndroidRuntime(15923):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1780)
11-22 08:35:38.032: E/AndroidRuntime(15923):    ... 11 more

Заранее спасибо за помощь лучшие регарды сафари

1 2

1 ответ:

Чтобы подчеркнуть точку зрения user370305 (опубликованный как отдельный ответ, так как многострочный код в комментариях не так легко прочитать):

// No good.
String notJsonObject = "This is not a JSON object.";
JSONObject jsonObject = new JSONObject(notJsonObject);

// Good.
String validJsonObject = "{\"foo\":\"bar\"}";
JSONObject jsonObject = new JSONObject(validJsonObject);