2016-04-24 121 views
0

我正在爲學校和這個項目的一個小項目工作,我需要從編碼成json的數據庫解析數據。現在,我已經成功地編碼了一個對象,但不是所有正在檢索的對象。解析來自while循環的json數據

代碼傳遞一個對象:

Response.Listener<String> responseListener2 = new Response.Listener<String>() { 
@Override 
public void onResponse(String response) { 
    try { 
     JSONObject jsonObject2 = new JSONObject(response); 
     Log.i("HIAAAAAAAAAAAAAA", response); 
     boolean tweet_success = jsonObject2.getBoolean("tweet_succes"); 
     String tweet_sendbyuser = jsonObject2.getString("tweet_send_by_user"); 
     String tweet_description = jsonObject2.getString("tweet_description"); 
     String tweet_favourites = jsonObject2.getString("tweet_favourites"); 
     String tweet_retweets = jsonObject2.getString("tweet_retweets"); 
     String tweet_reactions = jsonObject2.getString("tweet_reactions"); 
     boolean tweet_isReaction = jsonObject2.getBoolean("tweet_isReaction"); 
     String tweet_reactedTo = jsonObject2.getString("tweet_reactedTo"); 
     String tweet_dateSend = jsonObject2.getString("tweet_dateSend"); 
     Tweet tweet = new Tweet(tweet_sendbyuser, tweet_description, tweet_favourites, tweet_retweets, tweet_reactions, tweet_isReaction, tweet_reactedTo); 
     LoggedInDetails.getInstance().addTweet(tweet); 
     if (tweet_success) { 
      Toast.makeText(LoginActivity.this, "Parsing done", Toast.LENGTH_SHORT).show(); 
      Intent intent = new Intent(getApplicationContext(), HomeActivity.class); 
      intent.putExtra("username", LoggedInDetails.getInstance().getUsername()); 
      intent.putExtra("password", LoggedInDetails.getInstance().getPassword()); 
      startActivity(intent); 
     } else { 
      Toast.makeText(LoginActivity.this, "Error during parsing", Toast.LENGTH_SHORT).show(); 
     } 
    } catch (JSONException e) { 
     e.printStackTrace(); 
     Log.i("", response); 
    } 
}}; 

再有就是我做有它分析所有數據的代碼返回。但是這樣做是從第一行創建11個單獨的對象,但仍不能做第二或任何排什麼:

Response.Listener<String> responseListener2 = new Response.Listener<String>() { 
@Override 
public void onResponse(String response) { 
    try { 
     JSONObject jObject = new JSONObject(response.trim()); 
     Iterator<?> keys = jObject.keys(); 
     boolean tweet_success = false; 
     while (keys.hasNext()) { 
      String key = (String) keys.next(); 
      Log.i("HIAAAAAAAAAAAAAA", response); 
      tweet_success = jObject.getBoolean("tweet_succes"); 
      String tweet_sendbyuser = jObject.getString("tweet_send_by_user"); 
      String tweet_description = jObject.getString("tweet_description"); 
      String tweet_favourites = jObject.getString("tweet_favourites"); 
      String tweet_retweets = jObject.getString("tweet_retweets"); 
      String tweet_reactions = jObject.getString("tweet_reactions"); 
      boolean tweet_isReaction = jObject.getBoolean("tweet_isReaction"); 
      String tweet_reactedTo = jObject.getString("tweet_reactedTo"); 
      String tweet_dateSend = jObject.getString("tweet_dateSend"); 
      Tweet tweet = new Tweet(tweet_sendbyuser, tweet_description, tweet_favourites, tweet_retweets, tweet_reactions, tweet_isReaction, tweet_reactedTo); 
      LoggedInDetails.getInstance().addTweet(tweet); 

     }if (tweet_success) { 
      Toast.makeText(LoginActivity.this, "Parsing done", Toast.LENGTH_SHORT).show(); 
      Intent intent = new Intent(getApplicationContext(), HomeActivity.class); 
      intent.putExtra("username", LoggedInDetails.getInstance().getUsername()); 
      intent.putExtra("password", LoggedInDetails.getInstance().getPassword()); 
      startActivity(intent); 
     } else { 
      Toast.makeText(LoginActivity.this, "Error during parsing", Toast.LENGTH_SHORT).show(); 
     } 
    } catch (JSONException e) { 
     e.printStackTrace(); 
     Log.i("", response); 
    } 
}}; 

再有就是我的collect_tweet.php(僅重要部分)

if($fetch_tweets->execute()){ 
     $response1 = array(); 
     $response1["tweet_succes"] = false; 
     while($row = $fetch_tweets->fetch(PDO::FETCH_ASSOC)){ 
      $response1["tweet_succes"] = true; 
      $response1["succes"] = true; 
      $response1["tweet_id"] = $row["tweet_id"]; 
      $response1["tweet_send_by_user"] = $row['tweet_sendbyuser']; 
      $response1["tweet_description"] = $row['tweet_description']; 
      $response1["tweet_favourites"] = $row['tweet_favourites']; 
      $response1["tweet_retweets"] = $row['tweet_retweets']; 
      $response1["tweet_reactions"] = $row['tweet_reactions']; 
      $response1["tweet_isReaction"] = $row['tweet_isReaction']; 
      $response1["tweet_reactedTo"] = $row['tweet_reactedTo']; 
      $response1["tweet_dateSend"] = $row['tweet_dateSend']; 
      echo json_encode($response1); 
     } 
    }else{ 
     $response1["tweet_succes"] = false; 
     echo json_encode($response1); 
    } 
目前,即時通訊越來越在瀏覽器中JSON的

部分:(僞測試數據)

{ 
    "tweet_succes":true, 
    "succes":true, 
    "tweet_id":"1", 
    "tweet_send_by_user":"1", 
    "tweet_description":"Ja ik weet niet zo goed wat de eerste tweet moest zijn, dus dit is em maar he", 
    "tweet_favourites":"2, 3, 4", 
    "tweet_retweets":"2, 3, 4", 
    "tweet_reactions":"", 
    "tweet_isReaction":"false", 
    "tweet_reactedTo":"-1", 
    "tweet_dateSend":"2016-04-23 23:39:49" 
} 
{ 
    "tweet_succes":true, 
    "succes":true, 
    "tweet_id":"2", 
    "tweet_send_by_user":"2", 
    "tweet_description":"Ja ik weet niet zo goed wat de eerste tweet moest zijn, dus dit is em maar he", 
    "tweet_favourites":"2, 3, 4", 
    "tweet_retweets":"2, 3, 4", 
    "tweet_reactions":"", 
    "tweet_isReaction":"false", 
    "tweet_reactedTo":"-1", 
    "tweet_dateSend":"2016-04-23 23:40:49" 
} 

我可能分析錯了或者我需要使用,而不是對象JSONArray。

我的目標是根據我收到的數據進行推文。

在此先感謝〜

回答

0

您在返回多個單個陣列,而不是建立一個數組的數組和返回這一切一氣呵成。

這將所有的數據構建成一個答覆

$response1 = array(); 
$response1["tweet_succes"] = false; 
if($fetch_tweets->execute()){ 
    $response1["tweet_succes"] = true; 
    $response1["succes"] = true; 

    while($row = $fetch_tweets->fetch(PDO::FETCH_ASSOC)){ 
     $t = array(); 
     $t["tweet_id"] = $row["tweet_id"]; 
     $t["tweet_send_by_user"] = $row['tweet_sendbyuser']; 
     $t["tweet_description"] = $row['tweet_description']; 
     $t["tweet_favourites"] = $row['tweet_favourites']; 
     $t["tweet_retweets"] = $row['tweet_retweets']; 
     $t["tweet_reactions"] = $row['tweet_reactions']; 
     $t["tweet_isReaction"] = $row['tweet_isReaction']; 
     $t["tweet_reactedTo"] = $row['tweet_reactedTo']; 
     $t["tweet_dateSend"] = $row['tweet_dateSend']; 
     $response1[] = $t; 
    } 
}else{ 
    $response1["tweet_succes"] = false; 
} 

echo json_encode($response1); // finally return the complete array 

它也可以更簡單,如果你只查詢選擇完成,是這些領域並沒有其他的,那麼你可以寫

$response1 = array(); 
$response1["tweet_succes"] = false; 
if($fetch_tweets->execute()){ 
    $response1["tweet_succes"] = true; 
    $response1['results'] = $fetch_tweets->fetchAll(PDO::FETCH_ASSOC)){ 
}else{ 
    $response1["tweet_succes"] = false; 
} 

echo json_encode($response1); // finally return the complete array