Velas de upload lentas usando httpclient, Mime4j de Jame e método de postagem HTTPPOST
-
19-09-2019 - |
Pergunta
Estou enviando um pedaço de dados de vários dados usando httppost e alimentando -os em um método de execução de objetos httpclient da seguinte maneira:
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);
Agora, faça login e publicando trabalho - Fine, mas o upload é dolorosamente lento. Eu testei minha conexão com a Internet e é muito mais lento do que o que deveria ser (aproximadamente a velocidade de subida é de 1 MB/s, o upload de um arquivo de 3 MB está levando cerca de 5 minutos (em vez de 30s).
Alguém tem alguma ideia?
Solução
Descobri que o HTTPClient é como 9 vezes mais lento que o caminho regular no HTTPS. Eu não tenho idéia do porquê, alguém sabe o que está errado.
Aqui está basicamente o meu código
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();
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow