2

PHP MYSQLを使用してサーバーからデータを取得するネイティブAndroidアプリを作成しています

この[予定リスト]では、ユーザーが予定を再スケジュールできるようにしていますが、アイテムをタップすると空白のフォームが表示され、リストでクリックした特定の予定のデータが取得されません。

質問

AppointmentID を使用してフォームにデータを表示する方法は?

以下に、私が作成した必要なすべてのコードを示しています [クライアント側とサーバー側の両方]

UpcomingActivity.java:

        @Override
        public boolean onContextItemSelected(MenuItem item) {
            AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo)item.getMenuInfo();
            int menuItemIndex = item.getItemId();
            String[] menuItems = Cmd;
            String CmdName = menuItems[menuItemIndex];
            // Check Event Command
            if ("Cancel".equals(CmdName)) 
            {
                Toast.makeText(UpcomingActivity.this,"Selected Cancel",Toast.LENGTH_LONG).show();           
            }
            else if ("Reschedule".equals(CmdName)) 
            {
                Toast.makeText(UpcomingActivity.this,"Selected Update",Toast.LENGTH_LONG).show();

                String sAppointmentID = MyArrList.get(info.position).get("UserID").toString();                      
                Log.d(tag, "sAppointmentID :: " + sAppointmentID);

                Intent newActivity = new Intent(UpcomingActivity.this, UpdateActivity.class);
                newActivity.putExtra("UserID", sAppointmentID);                     
                startActivity(newActivity);
            }             
            return true;
        }

UpdateActivity.java:

            public void showInfo()
            {
                final TextView tAppointmentID = (TextView)findViewById(R.id.txtUsername);
                final TextView tType = (TextView)findViewById(R.id.txtName);
                final TextView tDate = (TextView)findViewById(R.id.txtEmail);
                final TextView tTime = (TextView)findViewById(R.id.txtTel);

                Button btnSave = (Button) findViewById(R.id.btnSave);
                Button btnCancel = (Button) findViewById(R.id.btnCancel);
                String url = "http://10.0.2.2/appointments/getByMemberID.php";

                Intent intent= getIntent();
                final String AppointmentID = intent.getStringExtra("AppointmentID");
                List<NameValuePair> params = new ArrayList<NameValuePair>();
                params.add(new BasicNameValuePair("sAppointmentID", AppointmentID));

                String resultServer  = getHttpPost(url,params);
                String strAppointmentID = "";               
                String strType = "";
                String strDate = "";
                String strTime = "";

                JSONObject c;
                try {
                    c = new JSONObject(resultServer);

                    strAppointmentID = c.getString("UserID");
                    Log.d(TAG, "String strAppointmentID" + strAppointmentID);
                    strType = c.getString("Type");
                    Log.d(TAG, "String strType" + strType);
                    strDate = c.getString("Date");
                    Log.d(TAG, "String strDate" + strDate);
                    strTime = c.getString("Time");
                    Log.d(TAG, "String strTime" + strTime);

                    if(!strAppointmentID.equals(""))
                    {
                        tAppointmentID.setText(strAppointmentID);
                        tType.setText(strType);
                        tDate.setText(strDate);
                        tTime.setText(strTime);
                    }   
                    else
                    {
                        tAppointmentID.setText("-");
                        tType.setText("-");
                        tDate.setText("-");
                        tTime.setText("-"); 
                        btnSave.setEnabled(false);
                        btnCancel.requestFocus();
                    }

                } catch (JSONException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }   
            }
4

4 に答える 4

3
  • オプション1

    Java EE Web サービスを開発し、サーバーでホストします。Android アプリは、データを Web サービスに関連付けてサーバーに送信する必要があります。サーバーはデータを受信し、そのデータに対して必要な処理を実行できます。サーバーは、Web サービスの同じ応答を通じて、さらにいくつかの情報を処理して応答することもできます。hello world Java EE をグーグルで検索する必要があります。見つけました。

    Java EE がローカル デスクトップ (または開発マシン) で動作するようになったら、WAR または EAR を EC2 にコピーして、アプリケーションをインターネット経由で実行できるようにすることができます。 DMZ。

  • オプション 2

    clientsocket を介して、Android アプリが接続する Java ソケット ベースの製品を開発できます。このようにして、データをシリアル化し、ストリーム経由で送信できます。そしてサーバー側でそれを逆シリアル化し、オブジェクトを再構築します。このアプローチには、より規律あるソフトウェア開発が必要です。初めて開発する場合は非常にバグが多い可能性があるため、オプション 1 をお勧めします。

私がいくつかの基本的な方向性を示したことを願っています。

于 2013-08-23T07:34:08.000 に答える
2
  1. まず、有効なAppointmentIDand UserIdandがあることを確認してください

  2. UpcomingActivity.javaat メソッドでonContextItemSelectedは、提供していないAppointmentID代わりに、にのみ提供UserIDしていますIntend

  3. リストしますが、無効Updateactivityな方法showDataでリクエストしintent.getStringExtra("AppointmentID")ています。

したがって、更新は次のUpcomingActivity.javaようになります

 public boolean onContextItemSelected(MenuItem item) {
        AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo)item.getMenuInfo();
        int menuItemIndex = item.getItemId();
        String[] menuItems = Cmd;
        String CmdName = menuItems[menuItemIndex];
        // Check Event Command
        if ("Cancel".equals(CmdName)) 
        {
            Toast.makeText(UpcomingActivity.this,"Selected Cancel",Toast.LENGTH_LONG).show();           
        }
        else if ("Reschedule".equals(CmdName)) 
        {
            Toast.makeText(UpcomingActivity.this,"Selected Update",Toast.LENGTH_LONG).show();

            String sAppointmentID = MyArrList.get(info.position).get("UserID").toString();                      
            Log.d(tag, "sAppointmentID :: " + sAppointmentID);

            Intent newActivity = new Intent(UpcomingActivity.this, UpdateActivity.class);
            newActivity.putExtra("UserID", sAppointmentID);
            newActivity.putExtra("AppointmentID", MyArrList.get(info.position).get("AppointmentID").toString());// <== here                     
            startActivity(newActivity);
        }             
        return true;
    }
于 2013-09-03T10:46:27.887 に答える
0

1)PHPコードが正常に動作しているかどうかを試してみてください...サーバー上で直接実行し、UserIdとappoinmentIdをパラメーターとして渡すことでそれを行うことができますか?

たとえば.... www.abc.com?sUserId=123?sAppointmentID=456

適切な出力を示している天気を参照してください。

2) getByMemberID.php を呼び出していますが、そのコードを指定していますが、そのために "AppointmentID" を渡していません。取得している php コードの天気も確認してください。

3) UpdateActivity.java の updateData.php の呼び出し時: 「AppointmentID」を提供していませんが、php コードで取得しています。デフォルトでは null 値が取得され、もちろんエラーになります。

于 2013-09-04T06:23:25.880 に答える