【问题标题】:Android https long polling: Cannot receive response when polling interval is longer than 70 secondsAndroid https长轮询:轮询间隔超过70秒时收不到响应
【发布时间】: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


    【解决方案1】:

    尝试添加:

    ConnManagerParams.setTimeout(params, CONNECTION_TIMEOUT);
    

    【讨论】:

      【解决方案2】:

      使用 URLConnection 并设置 readTimeOut。买很难说。我认为android网络层正在冻结打开的连接。 (我正在从事类似的项目。找不到打开的连接冻结的原因)

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2020-02-22
        • 2019-05-28
        • 2011-04-20
        • 1970-01-01
        • 2013-08-08
        • 2011-09-30
        • 1970-01-01
        相关资源
        最近更新 更多