Я работаю над небольшим проектом для школы, и для этого проекта мне нужно проанализировать данные из базы данных, которая закодирована в json. Теперь я был успешным, чтобы кодировать только один объект, но не все, которые извлекаются.Parsing json data from while loop
Код для передачи одного объекта:
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 вместо объекта.
Моя цель - сделать твиты на основе данных, которые я получаю.
Заранее спасибо ~