2016-04-01 3 views
0

Для начала я знаю, что заданы подобные вопросы. Среди всех вопросов я нашел тот, который мне помог: https://stackoverflow.com/a/29798632/4293403, но у меня возникла проблема с применением принятого ответа на мой собственный scenerio.Как анализировать вложенные массивы объектов JSON

Это содержание образец JSON:

[ 
    { 

    "title": "This a Sample title for each post_title", 

    "excerpt": "And this is a sample of the post_body", 

    "featured_picture": { 

     "source": "https://exapmple.com/blah/blah/image.jpg", 
     "year": "2015", 
     "ownwer": "Akim Man", 

    }, 

    },... 

И это код:

//This method will parse json data 
    private void parseData(JSONArray array){ 
     Log.d(TAG, "Parsing array"); 

     for(int i = 0; i<array.length(); i++) { 
      PostItems postItem = new PostItems(); 
      JSONObject jsonObject = null; 
      try { 
       jsonObject = array.getJSONObject(i); 
       postItem.setPost_title(jsonObject.getString(ConfigPost.TAG_POST_TITLE)); 
       postItem.setPost_body(jsonObject.getString(ConfigPost.TAG_POST_BODY)); 

       //Parsing featured_image object 
       for (int f = 0; f<array.length(); f++) { 
        JSONObject object = array.getJSONObject(f); 
        JSONObject postImage = object.getJSONObject("featured_picture"); 
        String imageURL = postImage.getString("source"); 
       } 

       postItem.setPost_image(imageURL(ConfigPost.TAG_POST_IMAGE)); 

      } catch (JSONException w) { 
       w.printStackTrace(); 
       //Toast.makeText(this, "Error in parsing Json", Toast.LENGTH_LONG).show(); 
      } 
      mPostItemsList.add(postItem); 
     } 

    } 

В строке postItem.setPost_image(imageURL(ConfigPost.TAG_POST_IMAGE)); Android Студия red_highlighting imageURL и когда я парить его вижу: «Невозможно разрешить метод imageURL (java.lang.String)».

Пожалуйста, что я делаю неправильно?

StackTrace из Implementaing Shadab Ансари Ответ

04-01 23:47:51.372 747-775/? D/StatusBarManagerService: manageDisableList userId=0 what=0x0 pkg=Window{74ca6f8 u0 com.example.Poster/com.example.Poster.MainActivity} 
04-01 23:47:51.372 17672-17672/com.example.Poster D/MainActivity: Parsing array 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.parseData(MainActivity.java:153) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity.access$000(MainActivity.java:43) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:118) 
04-01 23:47:51.382 17672-17672/com.example.Poster W/System.err:  at com.example.Poster.MainActivity$2.onResponse(MainActivity.java:109) 
04-01 23:47:57.708 747-798/? W/InputDispatcher: channel '74ca6f8 com.example.Poster/com.example.Poster.MainActivity (server)' ~ Consumer closed input channel or an error occurred. events=0x9 
04-01 23:47:57.708 747-798/? E/InputDispatcher: channel '74ca6f8 com.example.Poster/com.example.Poster.MainActivity (server)' ~ Channel is unrecoverably broken and will be disposed! 
04-01 23:47:57.708 747-823/? W/InputDispatcher: Attempted to unregister already unregistered input channel '74ca6f8 com.example.Poster/com.example.Poster.MainActivity (server)' 
04-01 23:47:57.708 747-823/? I/WindowState: WIN DEATH: Window{74ca6f8 u0 com.example.Poster/com.example.Poster.MainActivity} 
04-01 23:47:57.718 747-1385/? W/ActivityManager: Force removing ActivityRecord{ded20d6 u0 com.example.Poster/.MainActivity t19141}: app died, no saved state 
+0

Вы отлаживали данные, переданные в parseData()? –

+0

Отладка? Не поймите. – Faraday

ответ

0

Вы не имеете такой метод в вашем коде -

imageURL(String param) 

Я думаю, что вы хотите установить imageURL только. В этом случае ваш код должен выглядеть так:

for (int f = 0; f<array.length(); f++) { 
        JSONObject object = array.getJSONObject(f); 
        JSONObject postImage = object.getJSONObject("featured_picture"); 
        String imageURL = postImage.getString("source"); 
    postItem.setPost_image(imageURL); 
       } 
+0

Не работает Сэр, приложение вылетает и показывает системную ошибку в MainActivity.parseData и MainActivity.onResponse в stacktrace – Faraday

+0

Опубликуйте журналы сбоев, пожалуйста. –

+0

47: 51.372 17672-17672/com.example.Poster D/MainActivity: анализирующий массив 04-01 23: 47: 51.382 17672-17672/com.example.Poster W/System.err: at com.example.Poster. MainActivity.parseData (MainActivity.java:153) 04-01 23: 47: 51.382 17672-17672/com.example.Poster W/System.err: at com.example.Poster.MainActivity.access $ 000 (MainActivity.java: 43) – Faraday

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