处理连接和读取超时的RestClient调用在android



我有一个RestService接口,其中包含许多rest调用,我在整个应用程序中使用这些调用。

我正在设置处理connectionread-timeouts的超时

ClientHttpRequestFactory httpFactory = myRestService.getRestTemplate().getRequestFactory();
    if(httpFactory!=null)
    {
        if(httpFactory instanceof SimpleClientHttpRequestFactory)
        {
            ((SimpleClientHttpRequestFactory)httpFactory).setConnectTimeout(10*1000);
            ((SimpleClientHttpRequestFactory)httpFactory).setReadTimeout(30*1000);
        }
        else if(httpFactory instanceof HttpComponentsClientHttpRequestFactory)
        {
            ((HttpComponentsClientHttpRequestFactory)httpFactory).setConnectTimeout(10*1000);
            ((HttpComponentsClientHttpRequestFactory)httpFactory).setReadTimeout(30*1000);
        }
    }

但是我被困在处理超时的情况。我想使用这个方法,但是当rest调用失败时,它没有进入这个循环。

myRestService.getRestTemplate().setErrorHandler(new ResponseErrorHandler() 
    {
        @Override
        public boolean hasError(ClientHttpResponse paramClientHttpResponse) throws IOException 
        {
            Log.e(TAG, paramClientHttpResponse==null?"Null response" : ("Has Error : " + paramClientHttpResponse.getStatusText()+" , status code : "+paramClientHttpResponse.getStatusCode()));
            return false;
        }
        @Override
        public void handleError(ClientHttpResponse paramClientHttpResponse) throws IOException 
        {
            Log.e(TAG, paramClientHttpResponse==null?"Null response":("Handle Error : " + paramClientHttpResponse.getStatusText()+" , status code : "+paramClientHttpResponse.getStatusCode()));
        }
    });
有谁能帮我一下吗?

超时,坏网关,主机未找到和其他套接字异常不能被ErrorHandlers覆盖。ErrorHandlers的目标是查找ResponseErrorHandler方法签名中所述的现有响应中的错误。

所有套接字异常都会抛出RestClientException,并且必须在每个RestTemplate操作中捕获,例如在try…catch块。

try {
    repr = myRestService.getRestTemplate().getForObject(url, responseType, vars);
} catch (RestClientException e) {
    //Further exception processing, forming negative response should be here
}

查阅参考资料

希望有帮助。

相关内容

  • 没有找到相关文章

最新更新