Pergunta

Atualmente, estou tentando enviar alguns dados e aplicativo Android para um servidor php (ambos são controlados por mim).

Há um monte de dados coletados em um formulário no aplicativo, este é gravado no banco de dados.Tudo isso funciona.

No meu código principal, em primeiro lugar eu criar um JSONObject (eu cortei-la aqui, neste exemplo):

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

Em seguida, passar o objeto para enviar e receber a resposta:

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();
}

O HTTPPoster classe:

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;
}

Este obtém uma resposta, mas o servidor está retornando um 403 - Proibido resposta.

Eu tentei mudar o doPost função um pouco (isso é, na verdade, um pouco melhor, como eu disse, eu tenho um monte de enviar, basicamente 3 do mesmo formulário com dados diferentes - assim que eu criar 3 JSONObjects, um para cada formulário de entrada as entradas vêm do DB em vez de estático exemplo eu estou usando).

Em primeiro lugar, eu mudei a chamada mais um pouco:

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();
}

Ok, então as alterações para o doPost função:

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;
}

Ok, Então isso retorna uma resposta 200

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

No entanto os dados recebidos no servidor não pode ser analisado para uma string JSON.Está mal formatado acho que esta é a primeira vez que eu usei o JSON):

Se no arquivo php que eu faço um eco no $_POST['veículo'] eu recebo o seguinte:

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

Alguém pode me dizer onde eu estou errado, ou se há uma forma melhor de conseguir o que eu estou tentando fazer?Espero que o acima faz sentido!

Foi útil?

Solução

Depois de muita leitura e pesquisa descobri que o problema seja com, eu acredito que magic_quotes_gpc a ser habilitado no servidor.

Assim, usando:

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

No meu exemplo acima remove as barras e permite que o JSON para ser decodificado corretamente.

Ainda não sei por que o envio de uma StringEntity faz com que um erro 403?

Outras dicas

StringEntity s = new StringEntity(c.toString());
s.setContentEncoding("UTF-8");
s.setContentType("application/json");
request.setEntity(s);

Tente este código funciona para mim

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) {
}

}

Mudança

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

para

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

Ponto de interrogação no final é necessário quando você está tentando enviar parâmetros para o script php.

Tente este código funciona perfeitamente

*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"
        }
    }

em seguida, chamar HttpClient classe AsyncTask Como este:

aula particular YourTask se estende AsyncTask { private String error_msg = "erro de Servidor!";

    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

    }
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top