Отправка массива JSON с помощью PHP на Android Volley

Я отправляю массив данных из запроса MySQL и использую json_encode для этого:

public function getFriends($id){
$query = mysql_query(" SELECT uid, name, email
FROM users
RIGHT JOIN friendships
ON friendid2 = uid")        or die (mysql_error());

$jsonData = '{"tag":"friends",error":"false",';
$jsonData .= '"friends":[';

while($row = mysql_fetch_array($query)){
$i++;
$id = $row["uid"];
$name = $row["name"];
$email = $row["email"];
$jsonData .= '{"id":"'.$id.'","name":"'.$name.'","email":"'.$email.'"},';
}

$jsonData = chop($jsonData, ",");
$jsonData .= ']}';
echo json_encode($jsonData);

В Android LogCat, когда я создаю объект JSON, я вижу это:

 org.json.JSONException: Value {"tag":"friends",error":"false","friends":[{"id":"4","name":"GrubyJohny2","email":"grubyjohnny@gmail.com"},{"id":"243000000","name":"Wariacik","email":"karoltomczyk92@wp.com"}]} of type java.lang.String cannot be converted to JSONObject

Может кто-нибудь сказать мне, что я делаю не так? Потому что я искал кучу материалов, и я думаю, что мой синтаксис JSON является правильным.

Способ получения сообщения от сервера:

private void getFriendships(final String id) {

String tag_string_req = "req_friendships";
pDialog.setMessage("Sending Request for list of friends");
showDialog();
final String TAG = "List of friends request";
StringRequest strReq = new StringRequest(Request.Method.POST, AppConfig.URL_REGISTER, new Response.Listener<String>() {

@Override
public void onResponse(String response) {
Log.d(TAG, "Friendship request Response: " + response.toString());
hideDialog();
try {

JSONObject jObj = new JSONObject(response);
boolean error = jObj.getBoolean("error");

if (!error) {

Toast.makeText(getApplicationContext(), "Friends uploaded", Toast.LENGTH_LONG).show();

} else {

String errorMsg = jObj.getString("error_msg");
Toast.makeText(getApplicationContext(), errorMsg, Toast.LENGTH_LONG).show();
}
} catch (JSONException e) {
Toast.makeText(getApplicationContext(), e.getMessage(), Toast.LENGTH_LONG).show();
e.printStackTrace();
}

}
}, new Response.ErrorListener() {

@Override
public void onErrorResponse(VolleyError error) {
Log.e(TAG, "List of friends request Error: " + error.toString());

Toast.makeText(getApplicationContext(), error.getMessage(), Toast.LENGTH_LONG).show();
hideDialog();

}
}) {

@Override
protected Map<String, String> getParams() {
Map<String, String> params = new HashMap<String, String>();
params.put("tag", "friends");
params.put("sender", id);

return params;
}

};

AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
}

1

Решение

"friends",error":"false"

error ключ нуждается в кавычках с обеих сторон.

Вы можете скопировать / вставить JSON во многие бесплатные сервисы, такие как jsonlint.org это проанализирует вашу строку и сообщит вам, если и где ошибки.

Как отметил @Noman в комментариях, вы также можете просто построить всю совокупность данных в виде массива PHP (а не только их части), а затем просто json_encode все это в самом конце

$jsonData = array(
'tag' => 'friends',
'error' => 'false',
'friends' => array(),
);

while($row = mysql_fetch_array($query)) {
$jsonData['friends'][] = array(
'id'    => $row['uid'],
'name'  => $row['name'],
'email' => $row['email'],
);
}

echo json_encode($jsonData);

Также следует отметить, что mysql_query как и все mysql_* функции сейчас осуждается. Вы не должны писать новый код, который использует эти функции. Вместо этого вы должны научиться использовать либо PDO или же MySQLi расширения для связи с вашей базой данных.

0

Другие решения

Других решений пока нет …