【问题标题】:How to fix android.os.NetworkOnMainThread [duplicate]如何修复 android.os.NetworkOnMainThread [重复]
【发布时间】:2019-09-22 17:48:40
【问题描述】:

我得到"android.os.NetworkOnMainThreadException",即使我没有在我的主线程中运行任何与网络相关的东西。我该如何解决这个问题?

我实际上在 Eclipse 中尝试了代码,它工作得很好,但在我正在开发应用程序的 Android Studio 中却不行。

Testclass.java:

package com.*****.*****;



        import android.graphics.Bitmap;
        import android.os.AsyncTask;
        import android.view.View;

        import java.io.*;
        import java.net.*;
        import java.util.*;
        import javax.xml.xpath.*;
        import javax.xml.namespace.*;
        import org.xml.sax.InputSource;
        import javax.xml.parsers.DocumentBuilderFactory;
        import org.w3c.dom.Document;

abstract class Testclass {


    public static class NamespaceResolver implements NamespaceContext {
        private Document document;

        public NamespaceResolver(Document doc) {
            document = doc;
        }

        public String getNamespaceURI(String prefix) {
            if (prefix.equals("")) {
                return document.lookupNamespaceURI(null);
            } else {
                return document.lookupNamespaceURI(prefix);
            }
        }

        public String getPrefix(String namespaceURI) {
            return document.lookupPrefix(namespaceURI);
        }

        public Iterator<String> getPrefixes(String namespaceURI) {
            return null;
        }
    }

    public static String downloadString(String url) throws Exception {
        StringBuilder sb = new StringBuilder();
        try (BufferedReader r = new BufferedReader(new InputStreamReader(new URL(url).openStream(), "UTF-8"))) {
            String line;
            while ((line = r.readLine()) != null) {
                sb.append(line + "\n");
            }
        }
        return sb.toString();
    }

    public static Document createDocumentFromString(String xml) throws Exception {
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        factory.setNamespaceAware(true);
        return factory.newDocumentBuilder().parse(new InputSource(new StringReader(xml)));
    }

    static String value;

    public static String result() {

        try {
            String url = "http://opendata.fmi.fi/wfs/fin?service=WFS&version=2.0.0&request=GetFeature&storedquery_id=fmi::observations::mareograph::timevaluepair&fmisid=134223&";

            String xml = downloadString(url);
            Document document = createDocumentFromString(xml);
            XPath xpath = XPathFactory.newInstance().newXPath();
            xpath.setNamespaceContext(new NamespaceResolver(document));

            String time = xpath.evaluate("//wml2:MeasurementTimeseries[@gml:id='obs-obs-1-1-WATLEV']/wml2:point[last()]//wml2:time", document);
            value = xpath.evaluate("//wml2:MeasurementTimeseries[@gml:id='obs-obs-1-1-WATLEV']/wml2:point[last()]//wml2:value", document);
            System.out.format("time = %s; value = %s\n", time, value);
            return value;
        } catch (Exception e) {
            return "FAIL: " + e.toString();
        }
    }

}

在 android studio 中运行时的输出:"null" 并抛出 "android.os.NetworkOnMainThreadException"

在 Eclipse 中运行时的输出:"-97.0"(正确输出)

【问题讨论】:

  • 那么downloadString(String url)这个方法在做什么呢?
  • @KaranMer 它下载字符串并将其分配给一个名为“sb”的变量。

标签: java android


【解决方案1】:

您需要使用 Asyn Task 进行联网。 下面的链接给出了一个简单的例子 Async task in android

【讨论】:

  • 这可能是要走的路,我应该在 AsyncTask 线程中执行的代码的确切部分是什么?
  • result() 将被写入 AsyncTask 类的 doInBackground() 中。
  • 谢谢,会这样做的
【解决方案2】:

您需要在另一个线程上运行与网络相关的任务,如下所示:

Thread mThread = new Thread(new Runnable() {
@Override
public void run() {
    try  {
        //Put your code that you want to run in here
    } catch (Exception e) {
        e.printStackTrace();
    }
  }

现在,如果您不确定导致此问题的原因,您可以查看错误日志,它将引导您找到导致此问题的行。

您可以做的另一件事是添加带有错误描述的自定义日志/打印,稍后,您可以检查这些日志以查看是否有任何被调用(如果是,则表示您遇到了错误)

【讨论】:

  • 是的,我检查了错误日志,实际上并没有与此相关的任何内容。基本上现在我只需要找到产生错误的位置并在另一个线程中运行它。
  • 是的,如果错误日志没有帮助,只需添加错误日志并检查出来
  • 添加错误日志的最简单方法是什么?我是 java 新手,还在学习。
  • 检查this
  • 如果这有帮助,请接受答案,以便其他开发人员将来也能提供帮助。
猜你喜欢
  • 2022-01-06
  • 1970-01-01
  • 1970-01-01
  • 2021-02-20
  • 2017-10-12
  • 2017-08-14
  • 2018-01-14
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多