java - NetworkOnMainThreadException 即使在实现 AsyncTask 之后

标签 java android android-asynctask fatal-error forceclose

我不确定这里究竟发生了什么,但我已经实现了 AsyncTask,但我仍然收到 NetworkOnMainThreadException,我不知道为什么。

错误发生在第(116)行:

HttpResponse httpResponse = httpClient.execute(httpPost);

我觉得很奇怪,因为它在 doInBackground 中。

有什么建议吗?

来源:

import java.io.IOException;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

import android.os.AsyncTask;
import android.util.Log;

public class XMLParser extends AsyncTask {

    // constructor
    public XMLParser() {

    }

    /**
     * Getting XML from URL making HTTP request
     * 
     * @param url
     *            string
     * */

    /**
     * Getting XML DOM element
     * 
     * @param XML
     *            string
     * */
    public Document getDomElement(String xml) {
        Document doc = null;
        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
        try {

            DocumentBuilder db = dbf.newDocumentBuilder();

            InputSource is = new InputSource();
            is.setCharacterStream(new StringReader(xml));
            doc = db.parse(is);

        } catch (ParserConfigurationException e) {
            Log.e("Error: ", e.getMessage());
            return null;
        } catch (SAXException e) {
            Log.e("Error: ", e.getMessage());
            return null;
        } catch (IOException e) {
            Log.e("Error: ", e.getMessage());
            return null;
        }

        return doc;
    }

    /**
     * Getting node value
     * 
     * @param elem
     *            element
     */
    public final String getElementValue(Node elem) {
        Node child;
        if (elem != null) {
            if (elem.hasChildNodes()) {
                for (child = elem.getFirstChild(); child != null; child = child
                        .getNextSibling()) {
                    if (child.getNodeType() == Node.TEXT_NODE) {
                        return child.getNodeValue();
                    }
                }
            }
        }
        return "";
    }

    /**
     * Getting node value
     * 
     * @param Element
     *            node
     * @param key
     *            string
     * */
    public String getValue(Element item, String str) {
        NodeList n = item.getElementsByTagName(str);
        return this.getElementValue(n.item(0));
    }

    protected Object doInBackground(String url) {
        // TODO Auto-generated method stub

        String xml = null;

        try {
            // defaultHttpClient
            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpPost httpPost = new HttpPost(url);

            HttpResponse httpResponse = httpClient.execute(httpPost);
            HttpEntity httpEntity = httpResponse.getEntity();
            xml = EntityUtils.toString(httpEntity);

        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        // return XML
        return xml;
    }

    @Override
    protected Object doInBackground(Object... params) {
        // TODO Auto-generated method stub
        return null;
    }
}

洛卡特:

01-20 10:47:14.396: E/AndroidRuntime(1629): FATAL EXCEPTION: main
01-20 10:47:14.396: E/AndroidRuntime(1629): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidhive.xmlparsing/com.androidhive.xmlparsing.AndroidXMLParsingActivity}: android.os.NetworkOnMainThreadException
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread.access$700(ActivityThread.java:140)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1237)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.os.Looper.loop(Looper.java:137)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread.main(ActivityThread.java:4921)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at java.lang.reflect.Method.invokeNative(Native Method)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at java.lang.reflect.Method.invoke(Method.java:511)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at dalvik.system.NativeStart.main(Native Method)
01-20 10:47:14.396: E/AndroidRuntime(1629): Caused by: android.os.NetworkOnMainThreadException
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at java.net.InetAddress.getAllByName(InetAddress.java:214)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:670)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:509)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at com.androidhive.xmlparsing.XMLParser.doInBackground(XMLParser.java:116)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at com.androidhive.xmlparsing.AndroidXMLParsingActivity.onCreate(AndroidXMLParsingActivity.java:46)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.Activity.performCreate(Activity.java:5206)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
01-20 10:47:14.396: E/AndroidRuntime(1629):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2074)
01-20 10:47:14.396: E/AndroidRuntime(1629):     ... 11 more
01-20 10:47:14.406: I/Process(1629): Sending signal. PID: 1629 SIG: 9
01-20 10:48:04.316: D/AbsListView(2017): Get MotionRecognitionManager
01-20 10:48:04.331: D/AndroidRuntime(2017): Shutting down VM
01-20 10:48:04.331: W/dalvikvm(2017): threadid=1: thread exiting with uncaught exception (group=0x40ff42a0)
01-20 10:48:04.331: E/AndroidRuntime(2017): FATAL EXCEPTION: main
01-20 10:48:04.331: E/AndroidRuntime(2017): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidhive.xmlparsing/com.androidhive.xmlparsing.AndroidXMLParsingActivity}: android.os.NetworkOnMainThreadException
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread.access$700(ActivityThread.java:140)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1237)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.os.Looper.loop(Looper.java:137)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread.main(ActivityThread.java:4921)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at java.lang.reflect.Method.invokeNative(Native Method)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at java.lang.reflect.Method.invoke(Method.java:511)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at dalvik.system.NativeStart.main(Native Method)
01-20 10:48:04.331: E/AndroidRuntime(2017): Caused by: android.os.NetworkOnMainThreadException
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at java.net.InetAddress.getAllByName(InetAddress.java:214)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:670)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:509)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at com.androidhive.xmlparsing.XMLParser.doInBackground(XMLParser.java:116)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at com.androidhive.xmlparsing.AndroidXMLParsingActivity.onCreate(AndroidXMLParsingActivity.java:46)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.Activity.performCreate(Activity.java:5206)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
01-20 10:48:04.331: E/AndroidRuntime(2017):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2074)
01-20 10:48:04.331: E/AndroidRuntime(2017):     ... 11 more

最佳答案

你有两个doInBackground()方法,一个是覆盖AsyncTask的方法,你只返回null,和另一个是自定义实现,因为参数不匹配。

网络操作应该在覆盖的方法 doInBackground() 中完成,如果您在自己的自定义方法中执行它们,您将得到该异常。

关于java - NetworkOnMainThreadException 即使在实现 AsyncTask 之后,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21238370/

相关文章:

java - 如何通过浏览器在本地下发Java程序

java - mybatis的@TableGenerator

java - 如何使用 Content Provider 将文件放入 firebase (内容 ://) as source?

Android - RxJava vs AsyncTask 以防止 getActivity() 内存泄漏

java - 为 AsyncTask 实现一个常规的 JSON 解析器函数

java - 如何为具有共享 NFS 安装的 2 个节点设置 Jackrabbit Repository.xml?

java - 为简单的支持 vector 机计算拉格朗日乘数

java - 非常困惑的 Java.lang.RuntimeException : java. io.FileNotFoundException:

java - picasso 在 ListView 中向上滚动时不断重新加载图像,加载缓慢

android - 将 AudioTrack 与 JLayer 解码器一起使用