我正在尝试在我的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)工作正常,但可能连接丢失,我不明白为什么)。
感谢您的每一个回复。
答案 0 :(得分:1)
尝试添加:
ConnManagerParams.setTimeout(params, CONNECTION_TIMEOUT);
答案 1 :(得分:1)
使用URLConnection并设置readTimeOut。买它很难说。我认为android网络层是冻结开放的连接。 (我正在研究类似的项目。无法找到为什么开放连接冻结)