Обработать исключение "Сервер не отвечает" в AsyncTask

Как вы справляетесь с RuntimeException когда AsyncTask Не удалось подключиться к серверу, так как сервер по какой-то причине "не работает"?

Что я пытаюсь это куча catch блоки (не помогает):

        try {
            // Create Request to server and get response
            HttpGet httpget = new HttpGet(activity.getString(R.string.get_channels_lang_host));
            ResponseHandler<String> responseHandler = new BasicResponseHandler();
            downloadedString = httpclient.execute(httpget, responseHandler);
        }catch (MalformedURLException e) {
            Log.e("URL:","is a malformed URL");
            e.printStackTrace();
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
            Log.e("URL:"," UnsupportedEncodingException");
        } catch (ClientProtocolException e) {
            e.printStackTrace();
            Log.e("URL:"," ClientProtocolException");
        } catch (SocketTimeoutException e) {
            e.printStackTrace();
            Log.e("URL:"," SocketTimeoutException");
        } catch (ConnectTimeoutException e) {
            e.printStackTrace();
            Log.e("URL:"," ConnectTimeoutException");
        } catch (IOException e) {
            Log.e("URL:","IOException");
            e.printStackTrace();
        }
        if (downloadedString != null) {
            //parse request to object
            dataChannelsLangArrayList = JsonParser.getDataChannelsLang(downloadedString);
        } else {
            Toast.makeText(ActivityLoading.this, "Failed to load data. Restarting...", Toast.LENGTH_LONG).show();
            Global.restartApp(ActivityLoading.this);

        }

я все еще получаю ошибку времени выполнения:

04-09 11:31:29.610    3696-3719/tenkol.design.com.imbrecords E/AndroidRuntime﹕ FATAL EXCEPTION: AsyncTask #1
java.lang.RuntimeException: An error occured while executing doInBackground()
        at android.os.AsyncTask$3.done(AsyncTask.java:299)
        at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
        at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
        at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
        at java.util.concurrent.FutureTask.run(FutureTask.java:137)
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
        at java.lang.Thread.run(Thread.java:864)
 Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
        at android.os.Handler.<init>(Handler.java:121)
        at android.widget.Toast$TN.<init>(Toast.java:322)
        at android.widget.Toast.<init>(Toast.java:91)
        at android.widget.Toast.makeText(Toast.java:238)
        at tenkol.design.com.imbrecords.Global.restartApp(Global.java:115)
        at tenkol.design.com.imbrecords.ActivityLoading$LoadingAsyncTask.getChannelsLang(ActivityLoading.java:249)
        at tenkol.design.com.imbrecords.ActivityLoading$LoadingAsyncTask.doInBackground(ActivityLoading.java:157)
        at tenkol.design.com.imbrecords.ActivityLoading$LoadingAsyncTask.doInBackground(ActivityLoading.java:141)
        at android.os.AsyncTask$2.call(AsyncTask.java:287)
        at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
            at java.util.concurrent.FutureTask.run(FutureTask.java:137)
            at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
            at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
            at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
            at java.lang.Thread.run(Thread.java:864)

Меня больше всего интересуют два случая:

  1. Когда сервер не отвечает вообще;
  2. Когда время, затрачиваемое на запрос, слишком велико (например, при медленном интернете).

Как правильно обращаться с этим?

1 ответ

Решение

Can't create handler inside thread that has not called Looper.prepare()

Ну, вы создали Handler, но у нити, с которой он связан, нет очереди сообщений для публикации.

Пытаться new Handler(Looper.getMainLooper()) для обработчика, связанного с основным потоком.

Тогда вы можете опубликовать Runnable на нем, который показывает тост.

А если серьезно, почему бы не собрать исключение и не привести к обоим результатам, а обработать все это в onPostExecute()?

Public class Result<T>{
  public T data;
  public Exception exception;
  public String message;
}
Другие вопросы по тегам