48

I am using android-async-http and really liking it. I've run into a problem with POSTing data. I have to post data to the API in the following format: -

<request>
  <notes>Test api support</notes>
  <hours>3</hours>
  <project_id type="integer">3</project_id>
  <task_id type="integer">14</task_id>
  <spent_at type="date">Tue, 17 Oct 2006</spent_at>
</request>

As per the documentation, I tried doing it using RequestParams, but it is failing. Is this any other way to do it? I can POST equivalent JSON too. Any ideas?

morten.c
  • 3,414
  • 5
  • 40
  • 45
Mus
  • 1,860
  • 2
  • 16
  • 19

9 Answers9

129

Loopj POST examples - extended from their Twitter example:

private static AsyncHttpClient client = new AsyncHttpClient();

To post normally via RequestParams:

RequestParams params = new RequestParams();
params.put("notes", "Test api support"); 
client.post(restApiUrl, params, responseHandler);

To post JSON:

JSONObject jsonParams = new JSONObject();
jsonParams.put("notes", "Test api support");
StringEntity entity = new StringEntity(jsonParams.toString());
client.post(context, restApiUrl, entity, "application/json",
    responseHandler);
Timothy
  • 1,561
  • 1
  • 11
  • 6
22

@Timothy answer did not work for me.

I defined the Content-Type of the StringEntity to make it work:

JSONObject jsonParams = new JSONObject();
jsonParams.put("notes", "Test api support");

StringEntity entity = new StringEntity(jsonParams.toString());
entity.setContentType(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));

client.post(context, restApiUrl, entity, "application/json", responseHandler);

Good Luck :)

Danpe
  • 18,668
  • 21
  • 96
  • 131
  • while sending request it says - "Passed contentType will be ignored because HttpEntity sets content type". I am doing exactly what you have mentioned here. – Salman Khan Nov 18 '14 at 07:27
  • Thank you, thank you, thank you! setting the ContentType on BOTH the entity and post call got it working for me. – user2408952 Nov 20 '14 at 12:56
  • 1
    @SalmanKhan Yes, it's ok it still works like that. make sure you have set ContentType on *both* entity and post like user2408952 said. – Danpe Nov 22 '14 at 11:20
  • Since version 4.2 you can use `ContentType.APPLICATION_JSON.getMimeType()` to get `"application/json"` constant. – naXa stands with Ukraine Sep 01 '16 at 21:02
7

a better way to post json

RequestParams params = new RequestParams();
    params.put("id", propertyID);
    params.put("lt", newPoint.latitude);
    params.put("lg", newPoint.longitude);
    params.setUseJsonStreamer(true);

    ScaanRestClient restClient = new ScaanRestClient(getApplicationContext());
    restClient.post("/api-builtin/properties/v1.0/edit/location/", params, new AsyncHttpResponseHandler() {
        @Override
        public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
        }

        @Override
        public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) {
        }
    });
Samira
  • 844
  • 13
  • 17
  • This is the best if you have a service that recieve posted values from volley aswell. php code -> `$data = json_decode(file_get_contents("php://input"));` – Jose Jet Jul 31 '18 at 06:54
1

To post XML

protected void makePost() {
    AsyncHttpClient client = new AsyncHttpClient();
    Context context = this.getApplicationContext();
    String  url = URL_String;
    String  xml = XML-String;
    HttpEntity entity;
    try {
        entity = new StringEntity(xml, "UTF-8");
    } catch (IllegalArgumentException e) {
        Log.d("HTTP", "StringEntity: IllegalArgumentException");
        return;
    } catch (UnsupportedEncodingException e) {
        Log.d("HTTP", "StringEntity: UnsupportedEncodingException");
        return;
    }
    String  contentType = "string/xml;UTF-8";

    Log.d("HTTP", "Post...");
    client.post( context, url, entity, contentType, new AsyncHttpResponseHandler() {
        @Override
        public void onSuccess(String response) {
            Log.d("HTTP", "onSuccess: " + response);
        }
          ... other handlers
    });
}
Oyaji
  • 11
  • 1
0

just write your xml or json to a string and send to server, with proper headers or without. and yes set "Content-Type" to "application/json"

Just Variable
  • 892
  • 10
  • 19
0

If someone have a problem that httpclient send as Content-Type: text/plain, please refer this link: https://stackoverflow.com/a/26425401/361100

The loopj httpclient is somewhat changed (or has problem) which cannot override StringEntity native Content-Type to application/json.

Community
  • 1
  • 1
Youngjae
  • 24,352
  • 18
  • 113
  • 198
0

You can add the JSON string as an InputStream of some kind - I've used the ByteArrayStream, then passing it to the RequestParams you should set the correctMimeType

InputStream stream = new ByteArrayInputStream(jsonParams.toString().getBytes(Charset.forName("UTF-8")));
multiPartEntity.put("model", stream, "parameters", Constants.MIME_TYPE_JSON);
0

Just make JSONObject and then convert it to String "someData" and simply send with "ByteArrayEntity"

    private static AsyncHttpClient client = new AsyncHttpClient();
    String someData;
    ByteArrayEntity be = new ByteArrayEntity(someData.toString().getBytes());
    client.post(context, url, be, "application/json", responseHandler);

It is working fine for me.

AndroidLad
  • 687
  • 7
  • 14
0

To post xml file to a php server :

public class MainActivity extends AppCompatActivity {

/**
 * Send xml file to server via asynchttpclient lib
 */

Button button;
String url = "http://xxx/index.php";
String filePath = Environment.getExternalStorageDirectory()+"/Download/testUpload.xml";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    button = (Button)findViewById(R.id.button);

    button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            postFile();
        }
    });
}

public void postFile(){

    Log.i("xml","Sending... ");

    RequestParams params = new RequestParams();

    try {
        params.put("key",new File(filePath));
    }catch (FileNotFoundException e){
        e.printStackTrace();
    }

    AsyncHttpClient client = new AsyncHttpClient();

    client.post(url, params, new AsyncHttpResponseHandler() {
        @Override
        public void onSuccess(int i, cz.msebera.android.httpclient.Header[] headers, byte[] bytes) {
            Log.i("xml","StatusCode : "+i);
        }

        @Override
        public void onFailure(int i, cz.msebera.android.httpclient.Header[] headers, byte[] bytes, Throwable throwable) {
            Log.i("xml","Sending failed");
        }

        @Override
        public void onProgress(long bytesWritten, long totalSize) {
            Log.i("xml","Progress : "+bytesWritten);
        }
    });
}

}

After adding android-async-http-1.4.9.jar to android studio, go to build.gradle and add : compile 'com.loopj.android:android-async-http:1.4.9' under dependencies

And on AndroidManifest.xml add:

<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

Asif
  • 1
  • 1
  • 1