2014-09-04 3 views
1

У меня есть асинхронный запрос loopj в приложении для Android.loopj RequestHandle crash on cancel

Вот код:

private RequestHandle requestFetchAds; 
requestFetchAds = HJRestClient.post(getActivity(), encodedURL, params, new JsonHttpResponseHandler() {...}); 

Запрос выполняется в порядке и в некоторых ситуациях, мне нужно, чтобы отменить запрос. Вот отменяя код:

if (requestFetchAds != null && !requestFetchAds.isFinished() && !requestFetchAds.isCancelled()) { 
      Log.d(LOG_TAG, String.format("Cancelling request fetch ads")); 
      Log.d(LOG_TAG, String.format("Cancelling request: ") + (requestFetchAds.cancel(true) ? " succeeded" : " failed")); 
} 

Но он выходит из строя по методу requestFetchAds.cancel(true), и я не знаю, почему.

Вот лог:

09-04 16:14:42.530 3999-3999/com.haraj.haraj E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    android.os.NetworkOnMainThreadException 
      at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1144) 
      at org.apache.harmony.xnet.provider.jsse.OpenSSLSocketImpl.close(OpenSSLSocketImpl.java:996) 
      at org.apache.http.impl.SocketHttpClientConnection.shutdown(SocketHttpClientConnection.java:183) 
      at org.apache.http.impl.conn.DefaultClientConnection.shutdown(DefaultClientConnection.java:150) 
      at org.apache.http.impl.conn.AbstractPooledConnAdapter.shutdown(AbstractPooledConnAdapter.java:169) 
      at org.apache.http.impl.conn.AbstractClientConnAdapter.abortConnection(AbstractClientConnAdapter.java:378) 
      at org.apache.http.client.methods.HttpRequestBase.abort(HttpRequestBase.java:159) 
      at com.loopj.android.http.AsyncHttpRequest.cancel(AsyncHttpRequest.java:169) 
      at com.loopj.android.http.RequestHandle.cancel(RequestHandle.java:50) 
      at com.haraj.haraj.HJAdsListFragment.reloadAds(HJAdsListFragment.java:699) 
      at com.haraj.haraj.HJAdsListFragment$2.onClick(HJAdsListFragment.java:328) 
      at android.view.View.performClick(View.java:4475) 
      at android.view.View$PerformClick.run(View.java:18786) 
      at android.os.Handler.handleCallback(Handler.java:730) 
      at android.os.Handler.dispatchMessage(Handler.java:92) 
      at android.os.Looper.loop(Looper.java:137) 
      at android.app.ActivityThread.main(ActivityThread.java:5493) 
      at java.lang.reflect.Method.invokeNative(Native Method) 
      at java.lang.reflect.Method.invoke(Method.java:525) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025) 
      at dalvik.system.NativeStart.main(Native Method) 

Я также попытался отменить запрос, используя контекст, как:

HJRestClient.getHTTPClient().cancelRequests(getActivity(), true); 

Но это тоже не помогло.

Любая помощь будет оценена по достоинству.

+0

'Но он падает на метод requestFetchAds.cancel (true), и я не знаю почему.' Из-за android.os.NetworkOnMainThreadException ... – Selvin

+0

@Selvin, что это значит? Честно говоря, я не знаю. Я новичок в разработке Android. –

+0

честно, [google.com] (http://google.com) должен знать (или [рамочную документацию по android] (http://developer.android.com/reference/android/os/NetworkOnMainThreadException.html)) – Selvin

ответ

2

Я смог исправить ошибку, завернув запрос на отмену в AsyncTask следующим образом.

AsyncTask.execute(new Runnable() { 
     @Override 
     public void run() { 
      Log.d(LOG_TAG, String.format("Cancelling request: ") + (requestFetchAds.cancel(false) ? " succeeded" : " failed")); 

     } 
    }); 

Благодаря Selvin.