basse velocità di upload utilizzando HttpClient, di Jame Mime4j e HttpPost metodo di distacco
-
19-09-2019 - |
Domanda
sto caricando un pezzo in più parti di dati utilizzando HttpPost e inserendolo in un HttpClient oggetti metodo eseguito come segue:
HttpPost loginPost = new HttpPost(LOGIN_URL);
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("_email", mEmailAddress));
params.add(new BasicNameValuePair("lpassword", mPassword));
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(params, "UTF-8");
loginPost.setEntity(entity);
HttpResponse resp = mHttpClient.execute(loginPost);
HttpPost post = new HttpPost(UPLOAD_URL);
FileBody bin = new FileBody(file);
MultipartEntity me = new MultipartEntity();
me.addPart("stuff", new StringBody(stuff));
me.addPart("file", bin);
post.setEntity(new RequestEntityEx(me, handler));
mHttpClient.execute(post);
Ora, l'accesso e la pubblicazione di lavoro - bene, ma caricato è dolorosamente lento. Ho testato la mia connessione internet ed è molto più lento di quello che dovrebbe essere (circa. La velocità è 1Mb / s, il caricamento di un file di 3MB sta prendendo circa 5 minuti (invece di 30 anni).
Qualcuno ha qualche idea?
Soluzione
Ho trovato che HttpClient è come 9 volte più lento modo regolare su https. Non ho idea del perché, qualcuno sa che cosa c'è che non va.
Qui è fondamentalmente il mio codice
private static HttpClient httpClient = new DefaultHttpClient();
private static HttpPost httpPost = new HttpPost(RRD_URL);
public static String sendData(List<NameValuePair> data) {
StringBuffer buffer = new StringBuffer();
BufferedReader rd = null;
try {
httpPost.setEntity(new UrlEncodedFormEntity(data));
HttpResponse httpResponse = httpClient.execute(httpPost);
rd = new BufferedReader(new InputStreamReader(httpResponse.getEntity().getContent()));
String line;
while ((line = rd.readLine()) != null) {
buffer.append(line);
}
} catch (IOException e) {
e.printStackTrace(System.out);
} finally {
try {
if (rd != null) {
rd.close();
}
} catch (IOException e) {
e.printStackTrace(System.out);
}
}
return buffer.toString();
}
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow