【发布时间】:2011-06-09 19:55:30
【问题描述】:
我正在尝试在我的 android 应用程序上实现长轮询推送服务(基于 Microsoft 的 AUTD ActiveSync -> http://technet.microsoft.com/en-us/library/aa997252.aspx)。
我已经实现了在 Tomcat 7.0 上运行 Servlets 3.0 的服务器部分。我已经用 CURL 测试了我的 AsyncServlets,一切正常。
这就是我测试 AsyncServlet 的方式:
curl "https://webservice.mydomain.net/push?id=1&heartbeat=180000" --insecure --user user:password -D -
3 分钟后服务器响应(心跳间隔)
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Pragma: No-cache
Cache-Control: no-cache
Expires: Thu, 01 Jan 1970 01:00:00 CET
Content-Type: application/json;charset=ISO-8859-1
Content-Length: 0
Date: Sat, 15 Jan 2011 23:38:57 GMT
在我的 android 应用程序中,我使用了以下代码:
HttpParams httpParams = mDefaultHttpClient.getParams();
HttpConnectionParams.setConnectionTimeout(httpParams, CONNECTION_TIMEOUT);
HttpConnectionParams.setSoTimeout(httpParams, mHeartbeat + TIMEOUT_TOLERANCE);
mDefaultHttpClient.setParams(httpParams);
HttpGet httpGet = new HttpGet(mPushURL);
httpGet.addHeader("Accept", "application/json");
try {
Log.i(TAG, "Executing GET(PUSH) request " + httpGet.getRequestLine());
HttpResponse httpResponse = mDefaultHttpClient.execute(httpGet);
Log.i(TAG, httpResponse.getStatusLine().toString());
Log.i(TAG, convertInputStream(httpResponse.getEntity().getContent())); //For testing purposes
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
我进行了几次测试。如果我使用 70 秒的心跳间隔,我会收到响应。如果我使用 > 70 秒的心跳间隔,我会收到(在指定的心跳间隔之后)一个 SocketTimeoutException 而不是我的 HTTP 200 OK 响应。 (澄清一下:我设置的 SocketTimeout(SoTimeout) 工作正常,但可能连接丢失,我不知道为什么)。
感谢您的每一个回复。
【问题讨论】:
标签: java android timeout httpclient push