文档章节

android.os.NetworkOnMainThreadException如何解决?

今日竹石
 今日竹石
发布于 2014/05/06 13:50
字数 649
阅读 1702
收藏 1
点赞 0
评论 2

error如下:

05-06 11:38:43.104: D/(23666): android.os.NetworkOnMainThreadException

05-06 11:39:07.800: D/GestureDetector(23666): [Surface Touch Event] mSweepDown False, mLRSDCnt : -1 mTouchCnt : 5 mFalseSizeCnt:0

05-06 11:39:07.800: I/QCNEA(23666): |NIMS| getaddrinfo: hostname www.baidu.com servname NULL numeric 4 appname 

05-06 11:39:07.800: W/System.err(23666): android.os.NetworkOnMainThreadException

05-06 11:39:07.810: W/System.err(23666): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1128)

05-06 11:39:07.810: W/System.err(23666): at java.net.InetAddress.lookupHostByName(InetAddress.java:385)

05-06 11:39:07.810: W/System.err(23666): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)

05-06 11:39:07.810: W/System.err(23666): at java.net.InetAddress.getAllByName(InetAddress.java:214)

05-06 11:39:07.810: W/System.err(23666): at libcore.net.http.HttpConnection.<init>(HttpConnection.java:70)

05-06 11:39:07.810: W/System.err(23666): at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)

05-06 11:39:07.810: W/System.err(23666): at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)

05-06 11:39:07.810: W/System.err(23666): at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)

05-06 11:39:07.810: W/System.err(23666): at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)

05-06 11:39:07.820: W/System.err(23666): at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:316)

05-06 11:39:07.820: W/System.err(23666): at libcore.net.http.HttpEngine.connect(HttpEngine.java:311)

05-06 11:39:07.820: W/System.err(23666): at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:290)

05-06 11:39:07.830: W/System.err(23666): at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:240)

05-06 11:39:07.830: W/System.err(23666): at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:282)

05-06 11:39:07.830: W/System.err(23666): at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:177)

05-06 11:39:07.830: W/System.err(23666): at com.example.networkconnectiondemo.MainActivity.onClick(MainActivity.java:76)

05-06 11:39:07.840: W/System.err(23666): at android.view.View.performClick(View.java:4367)

05-06 11:39:07.840: W/System.err(23666): at android.view.View$PerformClick.run(View.java:17984)

05-06 11:39:07.840: W/System.err(23666): at android.os.Handler.handleCallback(Handler.java:725)

05-06 11:39:07.840: W/System.err(23666): at android.os.Handler.dispatchMessage(Handler.java:92)

05-06 11:39:07.840: W/System.err(23666): at android.os.Looper.loop(Looper.java:137)

05-06 11:39:07.840: W/System.err(23666): at android.app.ActivityThread.main(ActivityThread.java:5297)

05-06 11:39:07.840: W/System.err(23666): at java.lang.reflect.Method.invokeNative(Native Method)

05-06 11:39:07.840: W/System.err(23666): at java.lang.reflect.Method.invoke(Method.java:511)

05-06 11:39:07.840: W/System.err(23666): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)

05-06 11:39:07.840: W/System.err(23666): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)

05-06 11:39:07.840: W/System.err(23666): at dalvik.system.NativeStart.main(Native Method)

我的代码如下:

@Override

public void onClick(View v)

{

switch (v.getId())

{

case R.id.activity_main_btn:

try

{

// Toast.makeText(this, "I'm here!", Toast.LENGTH_LONG).show();

/* 获取url并获取数据 */

// 清空显示内容的文本框

tvShowContent.setText("");

// 获取用户输入的url

URL url = new URL(etInputUrl.getText().toString());

//URL url = new URL("http://www.baidu.com");

// 声明打开链接

URLConnection urlConnection = url.openConnection();

// 获取网页数据

BufferedReader bufferedReader = new BufferedReader(

new InputStreamReader(urlConnection.getInputStream()));

// 逐行读取时的字符串

String line = "";

// 读取数据

while ((line = bufferedReader.readLine()) != null)

{

Message message = new Message();

message.obj = line;

message.what = 0;

// 将数据显示在界面上

handler.sendMessage(message);

}


} catch (Exception e)

{

e.printStackTrace();

Log.d("", e.toString());

}

break;

。。。。。。。。。

通过debug可以发现在执行

// 获取网页数据

BufferedReader bufferedReader = new BufferedReader(

new InputStreamReader(urlConnection.getInputStream()));

这段代码时报的错。

那么如何修改呢?

根据api文档介绍,只要在调用这段代码之前加上如下代码即可:

StrictMode

.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()

.detectDiskReads().detectDiskWrites()

.detectNetwork() // or .detectAll() for all

// detectable problems

.penaltyLog().build());

StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()

.detectLeakedSqlLiteObjects()

.detectLeakedClosableObjects().penaltyLog()

.penaltyDeath().build());


© 著作权归作者所有

共有 人打赏支持
今日竹石
粉丝 41
博文 227
码字总数 181312
作品 0
朝阳
程序员
加载中

评论(2)

今日竹石
今日竹石

引用来自“mcloud”的评论

网络操作不要网络操作不要放主线程撒, 另外开一个线程做
ok,谢谢哦,这里只是一个简单的demo
mcloud
mcloud
网络操作不要网络操作不要放主线程撒, 另外开一个线程做
android.os.NetworkOnMainThreadException异常处理

第一种: public void onCreate(Bundle savedInstanceState) { 在android 2.3上设计的下载程序,在android 4.0上运行时报android.os.NetworkOnMainThreadException异常,原来在4.0中,访问网......

蒲成林 ⋅ 2013/12/01 ⋅ 0

异常:android.os.NetworkOnMainThreadException

Android 4.1项目:使用新浪微博分享时报:   android.os.NetworkOnMainThreadException 网上搜索后知道是因为版本问题,在4.0之后在主线程里面执行Http请求都会报这个错,也许是怕Http请求...

IT妖姬 ⋅ 2014/04/18 ⋅ 0

异常:android.os.NetworkOnMainThreadException

Android 4.1项目:使用新浪微博分享时报:   android.os.NetworkOnMainThreadException 网上搜索后知道是因为版本问题,在4.0之后在主线程里面执行Http请求都会报这个错,也许是怕Http请求...

tfc ⋅ 2013/01/04 ⋅ 0

网络请求----HttpURLConnection的get,post和图片加载

URLConnection是个抽象类,它有两个直接子类分别是HttpURLConnection和JarURLConnection。另外一个重要的类是URL,通常URL可以通过传给构造器一个String类型的参数来生成一个指向特定地址的U...

切切歆语 ⋅ 2016/12/05 ⋅ 0

安卓问题总结( android.os.NetworkOnMainThreadException异常)

问题描述: android.os.NetworkOnMainThreadException异常(不要在主线程访问网络资源) 问题分析: 造成这种异常的原因是安卓版本问题(仔细研究错误原因是代码不符合Android规范),网上搜...

火龙战士 ⋅ 2015/01/30 ⋅ 3

android创建子线程问题

private void runSQL(final String SQL, final String action, final runSqlCallback call) {Runnable runnable = new Runnable() {public void run() {try {Log.i("Run SQL-1", SQL);URL ur......

牟凌涛 ⋅ 2013/11/26 ⋅ 5

url.openStream()报错?

如下代码种的url.openStream()一执行就报错,访问网络的权限也已经给了,鼓捣半天办实在是不知道为什么,求大伙儿帮忙看下 protected void onCreate(Bundle savedInstanceState) {super.onCr...

debuglife ⋅ 2013/06/16 ⋅ 3

android 4.0下访问主进程访问网络和开启另外另外的线程

在android 2.3上设计的下载程序,在android 4.0上运行时报android.os.NetworkOnMainThreadException异常,原来在4.0中,访问网络不能在主程序中进行,有两个方法可以解决,一个是在主程序中增...

天空下的 ⋅ 2013/01/14 ⋅ 0

android.view.ViewRootImpl$CalledFromWrongThreadException;android.os.NetworkOnMainThreadException;

记录两个android 知识点 1.错误:android.os.NetworkOnMainThreadException 表示不能在主线程进行网络操作,android不允许在主线程请求网络等;但是有办法强制执行。。。 2.错误:android.v...

dubox ⋅ 2016/10/30 ⋅ 0

Windows环境下Android Studio系列8—SDK版本配置

问题的由来 在一次调试问题中,出现下面错误信息: 09-07 09:15:08.000 1342-1342/? W/System.err﹕ android.os.NetworkOnMainThreadException09-07 09:15:08.000 1342-1342/? W/System.err......

一配 ⋅ 2015/09/08 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

HiSDP —— 高效的C++软件开发平台

目前阿里集团每天有近1000PB的数据是通过LogAgent采集的,为了让LogAgent做到资源占用节省和高效采集,背后是基于HiSDP去构建的。 缘由 当决定采用C++编程语言去开发一个软件时,紧接着所面临...

阿里云云栖社区 ⋅ 1分钟前 ⋅ 0

zookeeper-3.4.12 下载与安装教程

一、zookeeper下载地址 http://mirrors.hust.edu.cn/apache/zookeeper/ 二、启动教程 把压缩包放在指定目录下 第三: 进入 conf文件夹底下 zoo_sample.cfg 文件名改成 zoo.cfg 第四步: 进入b...

泉天下 ⋅ 2分钟前 ⋅ 0

Oracle 中文日期转换

SELECT TO_date('2011年11月11日', 'yy"年"mm"月"dd"日"') FROM DUAL; 1. Oracle无法识别中文格式,所以添加双引号。 2. 后面的格式是指字符串在转换前的格式,而不是指转换后的格式。...

名侦探柯南 ⋅ 3分钟前 ⋅ 0

MySell:API Spring Boot

起步 类目 商品 订单

BeanHo ⋅ 6分钟前 ⋅ 0

Spring方法拦截器MethodInterceptor

参考资料 1、Spring方法拦截器MethodInterceptor 2、Sharding JDBC源码分析-JdbcMethodInvocation类的作用

哎小艾 ⋅ 9分钟前 ⋅ 0

正则表达式

元字符 元字符,又叫字符集,就是用一些特殊符号表示特定种类的字符或位置。 匹配字符 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 匹配...

wangchen1999 ⋅ 9分钟前 ⋅ 0

数据库数据导入Elasticsearch案例分享

基于bboss持久层和bboss elasticsearch客户端实现数据库数据导入es案例分享(支持各种数据库和各种es版本) 1.案例对应的源码 https://gitee.com/bboss/bboss-elastic/blob/master/bboss-el...

bboss ⋅ 10分钟前 ⋅ 0

动手---sbt(2)

参考 https://blog.csdn.net/leishangwen/article/details/46225587 建立一个chisel_max目录,文件内容如后面所述,现在开始执行命令: joe@joe-Aspire-Z3730:/media/sdb4/download/scala$ c......

whoisliang ⋅ 16分钟前 ⋅ 0

纯js实现最简单的文件上传(后台使用MultipartFile)

<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>XMLHttpRequest上传文件</title> <script type="text/javascript"> //图片上传 var xhr......

孟飞阳 ⋅ 21分钟前 ⋅ 0

iOS宇宙大战游戏、调试工具、各种动画、AR相册、相机图片编辑等源码

iOS精选源码 日期时间选择器,swift Space Battle 宇宙大战 SpriteKit游戏源码 LLDebugTool - 便捷的IOS调试工具(新增截屏功能) 相机扫描or长按识别二维码、FMDB、键盘动态高度、定位等 动画...

sunnyaigd ⋅ 22分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部