如何在php http请求中将数据存储在Android中的数组中

时间:2013-07-25 16:40:30

标签: php android

这是我的php代码:

<?php
include('connection.php');
$result = mysql_query("SELECT * FROM links");
while($row = mysql_fetch_array($result))
  {
$response["title"]=$row['title'];
$response["url"]=$row['url'];
echo json_encode($response);
  }

?>

我想将标题和网址存储在android中的数组中。 title [],url []。

我尝试搜索http请求但找不到任何有用的内容。

1 个答案:

答案 0 :(得分:0)

首先你应该在.php中进行一些更改,如下所示:

$r=mysql_query("select * FROM links",$con);
while($row=mysql_fetch_array($r))
{
$cls[]=$row;
}
print(json_encode($cls));
mysql_close($con);
?>

如果在运行此脚本时得到一些结果,则完成第一步。然后我们用Java编写一些代码。

这是我的一个项目的一部分,所以不要只是复制。需要根据您的需求进行一些调整:

public Map<String, String> getTitlesUrls()
{
    Map<String,String> TitlesUrl = new HashMap<String,String>();



    //http post
    try{
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost("http:/10.0.0.2/yourscript.php");
            HttpResponse response = httpclient.execute(httppost);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();
    }
    catch(Exception e)
    {
            Log.e("1: log_tag", "Error in http connection "+e.toString());
    }
    //convert response to string
    try
    {
            BufferedReader reader = new BufferedReader(new InputStreamReader(is,"UTF-8"),8);
            StringBuilder sb = new StringBuilder();            
            String line = null;
            while ((line = reader.readLine()) != null) 
            {
                    sb.append(line);
            }
            is.close();

            result=sb.toString();
    }
    catch(Exception e)
    {
            Log.e("2: log_tag", "Error converting result "+e.toString());
    }

    //parse json data
    try
    {
        JSONArray jArray = new JSONArray(result);           

        for(int i=0;i<jArray.length();i++)
        {
            JSONObject json_data = jArray.getJSONObject(i);
        }

        JSONObject json_data = jArray.getJSONObject(0);

        TitlesUrl.put("Title", String.valueOf(json_data.getString("Title")));
        TitlesUrl.put("URL", String.valueOf(json_data.getString("url")));


    }
    catch(JSONException e)
    {
            Log.e("3: log_tag", "Error parsing data "+e.toString());
    }

    return TitlesUrl;
}