loopj android-async-http请求有时根本没有响应

时间:2014-03-26 05:17:14

标签: android http-request loopj android-async-http

我正在使用此库从我的网络服务请求。它在onSuccess和onFailure中根本没有响应(这是我覆盖的唯一两种方法)。我测试了1.4.4和1.4.5(android-async-http-1.4.5-20131110.125018-1,这个更好,但有时仍会遇到问题)。我确定这不是网络问题,因为我的ios应用程序从未在同一Web服务中遇到此问题。在发生此问题后立即刷新时,我可以得到响应。

这是我的代码:

在requester.java中

public class Requester 
{

    public static void get(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {

    AsyncHttpClient client = newClient();
    client.get(getAbsoluteUrl(url), params, responseHandler);
}

public static void post(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {

    AsyncHttpClient client = newClient();
    client.post(getAbsoluteUrl(url), params, responseHandler);
}

private static String getAbsoluteUrl(String relativeUrl) {
    return Settings.BASE_URL + relativeUrl;
}

private static AsyncHttpClient newClient()
{
    AsyncHttpClient client = new AsyncHttpClient();
    client.setMaxRetriesAndTimeout(Settings.HTTP_TIMEOUT,Settings.HTTP_RETRIES);
    return client;
}
}

在我的活动中发出http请求:

    Requester.get(urlRequest, null, new JsonHttpResponseHandler()
    {
        @Override
        public void onSuccess(int statusCode, org.apache.http.Header[] headers, org.json.JSONArray objects)
        {
            Logger.logDebug(TAG, "request success for " + " " + objects.length() + " objects");
        }

        @Override
        public void onFailure(int statusCode, org.apache.http.Header[] headers, java.lang.Throwable throwable, org.json.JSONArray errorResponse)
        {
            Logger.logError(TAG,"Failed to request");
        }

    });

我在一些项目中使用了类似的来源。但都有同样的问题。我不知道这是我的代码或android-async-http库的问题。有人可以帮忙吗?谢谢。

顺便说一句,我通常使用与上述源代码相同的方法同时发出3个请求,但使用不同的URL。

2 个答案:

答案 0 :(得分:2)

我确认问题与多个请求有关。我的解决方案是替换另一个库:Volley库。问题解决了!

答案 1 :(得分:1)

我也遇到了这个问题,经过进一步的调查,我意识到如果收到的json响应不是正确的json格式,或者如果来自服务器的响应包含任何额外的字符,你将无法调用回调方法,尽管post或get将被处理,不会触发回调。检查服务器的响应以确保。