首页 > 代码库 > android.os.NetworkOnMainThreadException

android.os.NetworkOnMainThreadException

因为Http请求写在了主线程里, 在4.0之后在主线程里面执行Http请求都会报这个错,大概是怕Http请求时间太长造成程序假死的情况吧。

解决方法有两种,下面我分别介 绍:

第一种,是在主线程中直接忽略,强制执行。(不推荐这种方法,但是该方法修改起来简单)

在MainActivity文件的setContentView(R.layout.activity_main)下面加上如下代码

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

 如果,有报错就在class头上加上

@TargetApi(Build.VERSION_CODES.GINGERBREAD)@SuppressLint("NewApi")

在onCreate上面加上:

@SuppressLint("NewApi")

第二种,启动另一个线程执行网络连接任务,比如使用Thread、Runnable、Handler(推荐使用这种方法)

代码如下:

public void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    this.setContentView(R.layout.share_mblog_view);    new Thread(runnable).start();}Handler handler = new Handler(){    @Override    public void handleMessage(Message msg) {        super.handleMessage(msg);        Bundle data = http://www.mamicode.com/msg.getData();"string">"value");        Log.i("mylog","请求结果-->" + val);    }}Runnable runnable = new Runnable(){    @Override    public void run() {        //        // TODO: http request.        //        Message msg = new Message();        Bundle data = http://www.mamicode.com/new Bundle();        data.putString("value","请求结果");        msg.setData(data);        handler.sendMessage(msg);    }}