23

私は現在、Androidアプリケーションからphpサーバーにデータを送信しようとしています(両方とも私が制御しています)。

アプリのフォームで収集されたデータは大量にあり、これはデータベースに書き込まれます。これはすべて機能します。

私のメイン コードでは、まず JSONObject を作成します (この例では、ここでは省略しています)。

JSONObject j = new JSONObject();
j.put("engineer", "me");
j.put("date", "today");
j.put("fuel", "full");
j.put("car", "mine");
j.put("distance", "miles");

次に、オブジェクトを送信用に渡し、応答を受け取ります。

String url = "http://www.server.com/thisfile.php";
HttpResponse re = HTTPPoster.doPost(url, j);
String temp = EntityUtils.toString(re.getEntity());
if (temp.compareTo("SUCCESS")==0)
{
    Toast.makeText(this, "Sending complete!", Toast.LENGTH_LONG).show();
}

HTTPPoster クラス:

public static HttpResponse doPost(String url, JSONObject c) throws ClientProtocolException, IOException 
{
    HttpClient httpclient = new DefaultHttpClient();
    HttpPost request = new HttpPost(url);
    HttpEntity entity;
    StringEntity s = new StringEntity(c.toString());
    s.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));
    entity = s;
    request.setEntity(entity);
    HttpResponse response;
    response = httpclient.execute(request);
    return response;
}

これは応答を取得しますが、サーバーは 403 - Forbidden 応答を返しています。

doPost 関数を少し変更してみました (これは、送信するものがたくさんあると言ったように、実際には少し良くなりました。基本的に、異なるデータを持つ同じフォームが 3 つあるため、フォーム エントリごとに 1 つずつ、3 つの JSONObjects を作成します。私が使用している静的な例ではなく、DB から来ています)。

まず、呼び出しを少し変更しました。

String url = "http://www.myserver.com/ServiceMatalan.php";
Map<String, String> kvPairs = new HashMap<String, String>();
kvPairs.put("vehicle", j.toString());
// Normally I would pass two more JSONObjects.....
HttpResponse re = HTTPPoster.doPost(url, kvPairs);
String temp = EntityUtils.toString(re.getEntity());
if (temp.compareTo("SUCCESS")==0)
{
    Toast.makeText(this, "Sending complete!", Toast.LENGTH_LONG).show();
}

では、doPost 関数を次のように変更します。

public static HttpResponse doPost(String url, Map<String, String> kvPairs) throws ClientProtocolException, IOException 
{
    HttpClient httpclient = new DefaultHttpClient();
    HttpPost httppost = new HttpPost(url);
    if (kvPairs != null && kvPairs.isEmpty() == false) 
    {
        List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(kvPairs.size());
        String k, v;
        Iterator<String> itKeys = kvPairs.keySet().iterator();
        while (itKeys.hasNext()) 
        {
            k = itKeys.next();
            v = kvPairs.get(k);
            nameValuePairs.add(new BasicNameValuePair(k, v));
        }             
        httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
    }
    HttpResponse response;
    response = httpclient.execute(httppost);
    return response;
}

わかりましたので、これは応答 200 を返します

int statusCode = re.getStatusLine().getStatusCode();

ただし、サーバーで受信したデータを JSON 文字列に解析することはできません。フォーマットが悪いと思います(JSONを使用したのはこれが初めてです):

PHP ファイルで $_POST['vehicle'] に対してエコーを実行すると、次のようになります。

{\"date\":\"today\",\"engineer\":\"me\"}

どこが間違っているのか、または私がやろうとしていることを達成するためのより良い方法があるかどうかを誰かに教えてもらえますか? うまくいけば、上記は理にかなっています!

4

5 に答える 5

11

多くの読書と検索の後、問題があることがわかりました.magic_quotes_gpcがサーバーで有効になっていると信じています。

したがって、次を使用します。

json_decode(stripslashes($_POST['vehicle']));

上記の例では、スラッシュを削除し、JSON を適切にデコードできるようにしています。

StringEntity を送信すると 403 エラーが発生する理由がまだわかりませんか?

于 2010-03-29T22:38:31.473 に答える
4
StringEntity s = new StringEntity(c.toString());
s.setContentEncoding("UTF-8");
s.setContentType("application/json");
request.setEntity(s);
于 2010-12-09T02:23:22.507 に答える
1

私のために働くこのコードを試してください

public void postData(String result,JSONObject obj) {
// Create a new HttpClient and Post Header
HttpClient httpclient = new DefaultHttpClient();
HttpParams myParams = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(myParams, 10000);
HttpConnectionParams.setSoTimeout(myParams, 10000);

String json=obj.toString();

try {

    HttpPost httppost = new HttpPost(result.toString());
    httppost.setHeader("Content-type", "application/json");

    StringEntity se = new StringEntity(obj.toString()); 
    se.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));
    httppost.setEntity(se); 

    HttpResponse response = httpclient.execute(httppost);
    String temp = EntityUtils.toString(response.getEntity());
    Log.i("tag", temp);


} catch (ClientProtocolException e) {

} catch (IOException e) {
}

}

于 2012-02-22T06:35:58.890 に答える
0

完全に機能するこのコードを試してください

*For HttpClient class* download jar file "httpclient-4.3.6.jar" and put in libs folder then
Compile:   dependencies {compile files('libs/httpclient-4.3.6.jar')}

repositories {
        maven {
            url "https://jitpack.io"
        }
    }

次に、この AsyncTask の HttpClient クラスを次のように呼び出します。

private class YourTask extends AsyncTask { private String error_msg = "サーバーエラー!";

    private JSONObject response;



    @Override
    protected Boolean doInBackground(String... params) {
        try {
            JSONObject mJsonObject = new JSONObject();
            mJsonObject.put("user_id", "user name");
            mJsonObject.put("password", "123456");
            String URL=" Your Link"

            //Log.e("Send Obj:", mJsonObject.toString());

            response = HttpClient.SendHttpPost(URL, mJsonObject);
            boolean status = response != null && response.getInt("is_error") == 0; // response

            return status;
        } catch (JSONException | NullPointerException e) {
            e.printStackTrace();
            mDialog.dismiss();
            return false;
        }
    }

    @Override
    protected void onPostExecute(Boolean status) {
       // your code

    }
}
于 2016-11-04T09:28:55.740 に答える
0

変化する

(String url = "http://www.server.com/MainPage.php";)

(String url = "http://www.server.com/MainPage.php?";)

パラメーターを php スクリプトに送信しようとしている場合は、最後にクエスチョン マークが必要です。

于 2010-12-05T01:41:51.647 に答える