Попытка получить текст из текстового файла, расположенного на сервере

Я пытаюсь получить строки из текстового файла с сервера и показать его на ListView. Я вызываю getTextListFromUrl() из запроса на обновление, переопределяя метод onRefersh(). Но я где-то застрял. Вот мой код

public class ScreenTwoActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener {

    private static final String CLASS_TAG = ScreenTwoActivity.class.getSimpleName();

    private ListView mLvData;
    private SwipeRefreshLayout mSwipeRefreshLayout;
    private ArrayAdapter<String> mAdapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_screen_2);

        mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_referesh_layout);
        mLvData = (ListView) findViewById(R.id.lv_screen_2);
        mSwipeRefreshLayout.setOnRefreshListener(this);
    }

    @Override
    public void onRefresh() {
        getRefreshContent();
    }

    /**
     * On swipe refresh new data will being fetched from list
     */
    private void getRefreshContent() {

        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                mAdapter = new ArrayAdapter<String>(ScreenTwoActivity.this, android.R.layout.simple_list_item_1, getTextListFromUrl());
                mLvData.setAdapter(mAdapter);
                mSwipeRefreshLayout.setRefreshing(false);
            }
        }, 1000);
    }

    private List<String> getTextListFromUrl() {

        List<String> listTextData = new ArrayList<>();
        try {
            URL textUrl = new URL("http://thehealthybillion.com/assignment/q3.txt");
            BufferedReader bufferReader = new BufferedReader(new InputStreamReader(textUrl.openStream()));
            String stringBuffer;
            while ((stringBuffer = bufferReader.readLine()) != null) {
                Log.i(CLASS_TAG, stringBuffer);
                listTextData.add(stringBuffer);
            }
            bufferReader.close();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return  listTextData;
    }
}

Это ошибка, которую я получаю в журнале

android.os.NetworkOnMainThreadException
            at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
            at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
            at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
            at java.net.InetAddress.getAllByName(InetAddress.java:214)
            at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28)
            at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)
            at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)
            at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)
            at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)
            at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:296)
            at com.android.okhttp.internal.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:179)
            at java.net.URL.openStream(URL.java:470)
            at com.thb.vidyanand.assignmentthb.ScreenTwoActivity.getTextListFromUrl(ScreenTwoActivity.java:86)
            at com.thb.vidyanand.assignmentthb.ScreenTwoActivity.access$100(ScreenTwoActivity.java:22)
            at com.thb.vidyanand.assignmentthb.ScreenTwoActivity$1.run(ScreenTwoActivity.java:66)
            at android.os.Handler.handleCallback(Handler.java:733)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:149)
            at android.app.ActivityThread.main(ActivityThread.java:5257)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:817)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:633)
            at dalvik.system.NativeStart.main(Native Method)

Кто-нибудь может сказать мне, что с этим не так?


person Vid    schedule 14.08.2015    source источник


Ответы (3)


Вы выполняете сетевую задачу в своем основном потоке (потоке пользовательского интерфейса), поэтому он выдает NetworkOnMainThreadException. Переместите всю тяжелую работу, связанную с сетью, в рабочий поток, используя AyncTask или Handler.

Даже после использования Handler, если вы все еще получаете исключение, добавьте приведенный ниже код в файл Activity onCreate().

if (android.os.Build.VERSION.SDK_INT > 9) {
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
    StrictMode.setThreadPolicy(policy); 
}

Источник: Ошибка StrictMode$AndroidBlockGuardPolicy.onNetwork

См. StrictMode для получения дополнительной информации.

person Prudhvi    schedule 14.08.2015
comment
Но я вызываю этот метод getTextListFromUrl() только из обработчика. Вы можете проверить код. - person Vid; 14.08.2015
comment
Я вижу это сейчас, позвольте мне посмотреть, в чем проблема тогда. - person Prudhvi; 14.08.2015
comment
Какое устройство (версия ОС) вы используете для запуска этого приложения? - person Prudhvi; 14.08.2015
comment
Android версии 4.4.2 - person Vid; 14.08.2015
comment
stackoverflow.com/a/22395546/3701433 Думаю, этот ответ может вам помочь. Дайте мне знать, чтобы я мог отредактировать этот ответ и сделать его актуальным. - person Prudhvi; 14.08.2015

Используйте асинхронную задачу для получения данных с сервера. Не выполняйте сетевые действия в основном потоке. Пожалуйста, обратитесь к этим ссылкам:

Как исправить исключение android.os.NetworkOnMainThreadException?

android.os.NetworkOnMainThreadException с Android 4.2

person Rubanraj Ravichandran    schedule 14.08.2015
comment
Но я вызываю метод из обработчика. - person Vid; 14.08.2015

Когда вы подключаетесь к Интернету, вам нужно использовать AsyncTask и вызывать его из метода doInBackground.

Ваша ошибка может быть решена с помощью StrictMode.enableDefaults() в вашем onCreate, но используйте это только для отладки.

person Santiago    schedule 14.08.2015