2

我在 ListActivity 上得到“未找到项目”吐司。

注意:当我将 PHP 代码更改为“从项目中选择 *”时,会显示整个表格。但是当我尝试使用 Android/Java 中的 param/cat_id 值过滤它时,我得到一个空白

这是代码,首先:php

 <?php
      $sql=mysql_query("SELECT * FROM items WHERE cat_id = ' ".$_REQUEST['cat_id']." '");
    while($row=mysql_fetch_assoc($sql))
    $output[]=$row;
print(json_encode($output));
mysql_close();
 ?>

(我已经确认“cat_id”,我通过捆绑传递到以下活动的值就是它需要的值。)

安卓/Java:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    cat_id = getIntent().getExtras().getString("category_id");
    items = new ArrayList<String>();

    new task().execute();

}

 class task extends AsyncTask<String, String, Void> {

    @Override
    protected Void doInBackground(String... params) {
        String url_select = "http://www.---.com/---/items.php";

        param = new ArrayList<NameValuePair>();
        param.add(new BasicNameValuePair("category_id", cat_id));

        HttpClient httpClient = new DefaultHttpClient();
        HttpPost httpPost = new HttpPost(url_select);

        try {
            httpPost.setEntity(new UrlEncodedFormEntity(param));

            HttpResponse httpResponse = httpClient.execute(httpPost);
            HttpEntity httpEntity = httpResponse.getEntity();

            // read content
            is = httpEntity.getContent();

        } catch (Exception e) {

         //

        }

以及更远的下方

    protected void onPostExecute(Void v) {

        String item;
        try {
            jArray = new JSONArray(result);
            JSONObject json_data = null;
            for (int i = 0; i < jArray.length(); i++) {
                json_data = jArray.getJSONObject(i);
                item = json_data.getString("item");

                items.add(item);
            }
        } catch (JSONException e1) {
            Toast.makeText(getBaseContext(), "No Items Found",
                    Toast.LENGTH_LONG).show();
        } catch (ParseException e1) {
            e1.printStackTrace();
        }

我在 ListActivity 上得到“未找到项目”吐司。

注意:当我将 PHP 代码更改为“从项目中选择 *”时,会显示整个表格。但是当我尝试使用 Android/Java 中的 param/cat_id 值过滤它时,我得到一个空白。

4

1 回答 1

5

在您编写的 Java 代码上

 param.add(new BasicNameValuePair("category_id", cat_id));

但是在你写的 PHP 代码上

$_REQUEST['cat_id']

你应该把它改成

$_REQUEST['category_id']
于 2012-06-19T21:55:47.880 回答