Android https长轮询:轮询间隔超过70秒时无法接收响应

时间:2011-01-16 00:08:12

标签: java android timeout httpclient push

我正在尝试在我的Android应用程序上实现一个长轮询推送服务(基于微软AUTD ActiveSync - > http://technet.microsoft.com/en-us/library/aa997252.aspx)。

我已经意识到在Tomcat 7.0上运行Servlet 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)工作正常,但可能连接丢失,我不明白为什么)。

感谢您的每一个回复。

2 个答案:

答案 0 :(得分:1)

尝试添加:

ConnManagerParams.setTimeout(params, CONNECTION_TIMEOUT);

答案 1 :(得分:1)

使用URLConnection并设置readTimeOut。买它很难说。我认为android网络层是冻结开放的连接。 (我正在研究类似的项目。无法找到为什么开放连接冻结)