2

ListActivity で「アイテムが見つかりません」というトーストが表示されます。

注: PHP コードを「Select * from items」に変更すると、テーブル全体が表示されます。しかし、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 コードを「Select * from items」に変更すると、テーブル全体が表示されます。しかし、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 に答える