我正在使用此库从我的网络服务请求。它在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。
答案 0 :(得分:2)
我确认问题与多个请求有关。我的解决方案是替换另一个库:Volley库。问题解决了!
答案 1 :(得分:1)
我也遇到了这个问题,经过进一步的调查,我意识到如果收到的json响应不是正确的json格式,或者如果来自服务器的响应包含任何额外的字符,你将无法调用回调方法,尽管post或get将被处理,不会触发回调。检查服务器的响应以确保。