如何修复 android.os.NetworkOnMainThread [重复]
Posted
技术标签:
【中文标题】如何修复 android.os.NetworkOnMainThread [重复]【英文标题】:How to fix android.os.NetworkOnMainThread [duplicate] 【发布时间】: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”的变量。
【参考方案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 如果这有帮助,请接受答案,以便其他开发人员将来也能提供帮助。以上是关于如何修复 android.os.NetworkOnMainThread [重复]的主要内容,如果未能解决你的问题,请参考以下文章