使用 PHP 将 JSON 数组发送到 Android Volley

Posted

技术标签:

【中文标题】使用 PHP 将 JSON 数组发送到 Android Volley【英文标题】:Sending JSON array using PHP to Android Volley 【发布时间】: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); 可能会导致问题 【参考方案1】:
"friends",error":"false"

error 键需要双引号。

您可以在许多免费服务中复制/粘贴 JSON,例如 jsonlint.org,它会为您解析字符串并告诉您是否存在错误以及错误在哪里。

正如@Noman 在 cmets 中指出的那样,您也可以将全部数据构建为 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 扩展来与您的数据库进行通信。

【讨论】:

您需要更新您的问题,说明您如何尝试将您从 Android 应用程序获取的字符串转换为 JSON。如果来自 PHP 的 JSON 是有效的,那么在你的情况下 PHP 不是问题。 我按照您的要求更新了我的问题。我粘贴了您的代码,但在 LogCat 中我得到:Parse error: syntax error, unexpected '[' in /android_api/include/DB_Functions.php on line 79第79行是:$jsonData = [ 在引入短数组语法之前,您可能使用的是 PHP 版本。我会更新答案以不使用它。 没有问题,很高兴为您提供帮助

以上是关于使用 PHP 将 JSON 数组发送到 Android Volley的主要内容,如果未能解决你的问题,请参考以下文章

如何通过 JSON 将数组从 php 解压到 Swift

如何将商品信息发送到paypal?

通过 jQuery Ajax 发送 Json 数组

使用 ajax 将 JSON 发送到 PHP

将 json 转换为多维 PHP 数组

Ajax以JSON访问从PHP返回的多维数组