2016-04-24 120 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