HttpURLConnection.getInputStream занимает очень много времени по сравнению с iPhone App, в котором используются одни и те же серверные службы.HttpURLConnection.getInputStream очень медленно
Следующий код используется для обслуживания:
date= new java.util.Date();
Log.d("time","Time Stamp before posting "+new Timestamp(date.getTime()));
URL ur= new URL(url);
HttpURLConnection conn = (HttpURLConnection) ur.openConnection();
conn.setRequestProperty("Connection", "close");
conn.setReadTimeout(10000);
conn.setConnectTimeout(15000);
conn.setRequestMethod("POST");
conn.setDoInput(true);
conn.setDoOutput(true);
OutputStream os = conn.getOutputStream();
BufferedWriter writer = new BufferedWriter(
new OutputStreamWriter(os, "UTF-8"));
writer.write(getQuery(nameValuePairs));
writer.close();
os.close();
conn.connect();
StringBuffer response=null;
try{
Log.d("time","Time Stamp bfr InputStream "+new Timestamp(date.getTime()));
InputStream is = conn.getInputStream();
date= new java.util.Date();
Log.d("time","Time Stamp aftr InputStream "+new Timestamp(date.getTime()));
BufferedReader rd = new BufferedReader(new InputStreamReader(is));
String line;
response = new StringBuffer();
while((line = rd.readLine()) != null) {
response.append(line);
response.append('\r');
}
rd.close();
response.toString();
result=response.toString();
} catch (Exception e) {
}
Чтобы проверить, где служба занимает много времени, я ставлю запись журнала для печати TimeStamp.
Среднее время для процесса выглядит следующим образом:
Среднее время для размещения на сервере занимает менее 2 мили секунды
Среднее время для создания входного потока занимает почти 5 секундСреднее время для записи ответа менее 2 мил секунд.
Любая идея о том, почему поток ввода занимает много времени, что делает весь сервис очень медленным?
Вы имеете в виду, что видели быстрые сбои соединения, когда вы их получили. Трудно понять, как это решает проблему OP. – EJP