【发布时间】:2015-07-21 00:35:30
【问题描述】:
我正在从 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":"gruby@gmail.com"},{"id":"243000000","name":"Wariacik","email":"karol@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);
}
【问题讨论】:
-
你为什么不用
json_encodephp.net/manual/en/function.json-encode.php -
请添加您的 Java 代码。我认为您正在使用这行
JSONArray jArray = new JSONArray(result);可能会导致问题
标签: php android mysql json android-volley