Java NetworkOnMainThreadException 从 URL 读取 csv 文件

标签 java android csv url openstreetmap

您好,我正在使用 android studio 创建一个应用程序,但我遇到了一个错误,事实证明我自己很难解决。我想要做的就是从 url 读取 CSV 文件,并将每一行的值添加到 map 标记中。我可以轻松地从文件中读取并将其添加到我的标记中,但是这个 url csv 读取对我来说是一个挑战:(。请问我的错误是什么,或者更好的是它也可以简化

HttpURLConnection conn = null;
    try {
        URL url = new URL("http://www.free-map.org.uk/course/mad/ws/get.php?username=user002&format=csv");
        conn = (HttpURLConnection) url.openConnection();
        InputStream in = conn.getInputStream();
        if(conn.getResponseCode() == 200)
        {
            BufferedReader br = new BufferedReader(new InputStreamReader(in));
            String inputLine;
            while ((inputLine = br.readLine()) != null) {
                String[] comps = inputLine.split(",");
                if (comps.length == 5) {
                    OverlayItem currentItem = new OverlayItem(comps[0], comps[2], new GeoPoint(Double.parseDouble(comps[4]), Double.parseDouble(comps[3])));
                    pois.addItem(currentItem);
                }
            }
        }

    }catch (IOException e){
        new AlertDialog.Builder(this).setMessage("ERROR: "+e).show();
    }
    finally
    {
        if(conn!=null)
            conn.disconnect();
    }

我将此代码放置在我的 on Resume() 中,以测试它是否有效。这些是 Logcat 中显示的错误。

E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: com.example.edwin.mapping, PID: 2048
                  java.lang.RuntimeException: Unable to resume activity {com.example.edwin.mapping/com.example.edwin.mapping.HelloMap}: android.os.NetworkOnMainThreadException
                      at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2788)
                      at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2817)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2250)
                      at android.app.ActivityThread.access$800(ActivityThread.java:135)
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
                      at android.os.Handler.dispatchMessage(Handler.java:102)
                      at android.os.Looper.loop(Looper.java:136)
                      at android.app.ActivityThread.main(ActivityThread.java:5017)
                      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:779)
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                      at dalvik.system.NativeStart.main(Native Method)
                   Caused by: 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 com.example.edwin.mapping.HelloMap.onResume(HelloMap.java:158)
                      at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1192)
                      at android.app.Activity.performResume(Activity.java:5310)
                      at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2778)
                      at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2817) 
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2250) 
                      at android.app.ActivityThread.access$800(ActivityThread.java:135) 
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
                      at android.os.Handler.dispatchMessage(Handler.java:102) 
                      at android.os.Looper.loop(Looper.java:136) 
                      at android.app.ActivityThread.main(ActivityThread.java:5017) 
                      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:779) 
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                      at dalvik.system.NativeStart.main(Native Method) 
Application terminated.

最佳答案

使用异步任务来执行网络操作。不要在 UI 线程上运行它。

例如:

private class ReadFile extends AsyncTask<String, Void, String> {

    @Override
    protected String doInBackground(String... params) {
       HttpURLConnection conn = null;
        try {
            URL url = new URL("http://www.free-map.org.uk/course/mad/ws/get.php?username=user002&format=csv");
            conn = (HttpURLConnection) url.openConnection();
            InputStream in = conn.getInputStream();
            if(conn.getResponseCode() == 200)
            {
                BufferedReader br = new BufferedReader(new InputStreamReader(in));
                String inputLine;
                while ((inputLine = br.readLine()) != null) {
                    String[] comps = inputLine.split(",");
                    if (comps.length == 5) {
                        OverlayItem currentItem = new OverlayItem(comps[0], comps[2], new GeoPoint(Double.parseDouble(comps[4]), Double.parseDouble(comps[3])));
                        pois.addItem(currentItem);
                    }
                }
            }

        }catch (Exception e){
            Log.e("Error, e.toString());
        }
        finally
        {
            if(conn!=null)
                conn.disconnect();
        }
        return null;
    }

    @Override
    protected void onPostExecute(String result) {

    }

    @Override
    protected void onPreExecute() {}
}

现在使用以下方式调用它:

new ReadFile().execute("");

关于Java NetworkOnMainThreadException 从 URL 读取 csv 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43328693/

相关文章:

android网络更改广播接收器并获取网络类型

android - FloatingActionButton 和 Snackbar 的导入语句出错

vba - 在 Excel for Mac 2016 中另存为 CSV

java - 如何在firefox中提示用户下载java applet?

java - 抽象类逻辑问题

java - ParseQuery NullPointer 异常悖论

csv - 使用 JMeter 在 CVS 日志中记录 cookie

excel - 删除 Ms Excel 2010 中的空列

java - 两个字符串的交错

java - 使用 Hibernate Envers 手动设置修订日期