android4.0以后不能在主线程发起网络请求,该异步网络请求。

new Thread(new Runnable()
{
@Override
public void run()
{
// TODO Auto-generated method stub
gethttp();
}
}).start(); //这段代码在主线程中调用,开启一个线程
	public void gethttp()
{ String addr = "", name = "";
StringBuilder stringBuilder = new StringBuilder();
String urlString = "";
if (chkbd.isChecked() == true)
{
urlString = String
.format("http://api.map.baidu.com/geocoder/v2/?ak=bjj7HFkUUoHs07rnVNM07TQg&coordtype="
+ "bd09ll"
+ "&callback=renderReverse&location="
+ latlng[0]
+ ","
+ latlng[1]
+ "&output=json&pois=1");
} else
{
urlString = String
.format("http://api.map.baidu.com/geocoder/v2/?ak=bjj7HFkUUoHs07rnVNM07TQg&coordtype="
+ "wgs84ll"
+ "&callback=renderReverse&location="
+ latlng[0]
+ ","
+ latlng[1]
+ "&output=json&pois=1");
}
Log.i(TAG, "latitude:" + latlng[0] + " longitude:" + latlng[1]);
/** 这里采用get方法,直接将参数加到URL上 */
Log.i(TAG, urlString); /** 新建HttpClient */
HttpClient client = new DefaultHttpClient();
/** 采用GET方法 */
HttpGet get = new HttpGet(urlString);
try
{
/** 发起GET请求并获得返回数据 */
Log.i(TAG, "发起GET请求并获得返回数据");
Log.e(TAG, "ces1");
HttpResponse response = client.execute(get);
int code = response.getStatusLine().getStatusCode();// 返回响应码
Log.e(TAG, "响应码code=" + code);
HttpEntity entity = response.getEntity();
BufferedReader buffReader = new BufferedReader(
new InputStreamReader(entity.getContent()));
StringBuffer strBuff = new StringBuffer();
String result = null;
while ((result = buffReader.readLine()) != null)
{
strBuff.append(result);
} /** 解析JSON数据,获得物理地址 */
// Log.i(TAG, "解析JSON数据,获得物理地址"+strBuff+" oo");
int indexAdd1 = 0, indexAdd2 = 0, indexAdd3 = 0, indexAdd4 = 0;
indexAdd1 = strBuff.indexOf("status", 1);
Log.i(TAG, "indexAdd1=" + indexAdd1);
String status = strBuff.substring(indexAdd1 + 8, indexAdd1 + 9);
Log.i(TAG, "status=" + status);
if (strBuff != null && strBuff.length() > 0 && status.equals("0"))
{ indexAdd1 = strBuff.indexOf("formatted_address", 1); indexAdd2 = strBuff.indexOf("pois", indexAdd2); indexAdd1 = strBuff.indexOf("addr", indexAdd2);
while (indexAdd1 > 1)
{ Log.i(TAG, "indexAdd1=" + indexAdd1 + " indexAdd2="
+ indexAdd2);
indexAdd2 = strBuff.indexOf("cp", indexAdd1);
addr = strBuff.substring(indexAdd1 + "addr".length() + 3,
indexAdd2 - 3);
stringBuilder.append("地址:" + addr);
indexAdd3 = strBuff.indexOf("name", indexAdd2);
indexAdd4 = strBuff.indexOf("poiType", indexAdd3);
name = strBuff.substring(indexAdd3 + "addr".length() + 3,
indexAdd4 - 3);
stringBuilder.append(" 名称:" + name + "\n");
indexAdd1 = strBuff.indexOf("addr", indexAdd4);
Log.e(TAG, "addr=" + addr + "\nname=" + name);
}
; } else if (status.equals("1"))
{
stringBuilder.append("百度服务器错误");
} else if (status.equals("21"))
{
stringBuilder.append("from非法");
} else if (status.equals("22"))
{
stringBuilder.append("to非法");
} else
{
stringBuilder.append("coords非法");
}
} catch (Exception e)
{
Log.i(TAG, "获取物理位置出现错误" + e.getMessage()); } finally
{
get.abort();
// stringBuilder=null;
client = null;
}
Log.i(TAG, "JSON:" + stringBuilder.toString());
        // 1、实例化一个Message对象
Message message = Message.obtain();
// 将图片流赋值给Message对象
message.obj = stringBuilder.toString();
// 定义标签
message.what = ;
// 3、发送消息到主线程中的Handler
mHandler.sendMessage(message);
} // 2、在主线程中实例化Handler对象
Handler mHandler = new Handler()
{ @Override
public void handleMessage(Message msg)
{
// TODO Auto-generated method stub
super.handleMessage(msg);
// 4、接收消息并执行UI的更新操作
if (msg.obj != null)
{
showText.setText((String) msg.obj);
} else
{
Log.i(TAG, "不能读取到网络信息!");
}
} };

android4.0 HttpClient 以后不能在主线程发起网络请求的更多相关文章

  1. Android4.0 以后不允许在主线程进行网络连接

    Android4.0 以后不允许在主线程进行网络连接,否则会出现 android.os.NetworkOnMainThreadException.因此,必须另起一个线程进行网络连接方面的操作. pac ...

  2. 一个App带你学会Retrofit2.0,麻麻再也不用担心我的网络请求了!

    Retrofit.Retrofit.Retrofit,越来越多的人在玩这个网络请求框架,这个由squareup公司开源的网络请求框架确实挺好用,今天我们就来看一下这个东东怎么玩! Retrofit作为 ...

  3. android.os.NetworkOnMainThreadException 在4.0之后谷歌强制要求连接网络不能在主线程进行访问

    谷歌在4.0系统以后就禁止在主线程中进行网络访问了,原因是: 主线程是负责UI的响应,如果在主线程进行网络访问,超过5秒的话就会引发强制关闭, 所以这种耗时的操作不能放在主线程里.放在子线程里,而子线 ...

  4. android4.0访问不能网络解决方法

    @SuppressLint("NewApi")protected void onCreate(Bundle savedInstanceState) {StrictMode.setT ...

  5. (转)electron主线程中通过mainWindow.webContents.send发送事件,渲染线程接收不到

    转自 https://segmentfault.com/q/1010000015599245/ 准备实现的功能: 页面1(渲染进程1)中点击按钮,发送事件给到主进程.主进程成功接收事件后,通过main ...

  6. android4.0以上访问网络不能在主线程中进行以及在线程中操作UI的解决方法

    MONO 调用一个线程操作UI 然后报Only the original thread that created a view hierarchy can touch its views.错误 goo ...

  7. Android4.0 主线程不能访问网络异常解决办法

    从两个方面说下这个问题: 1. 不让访问网络的原因 2. 解决该问题的办法 不让访问网络的原因: 由于对于网络状况的不可预见性,很有可能在网络访问的时候造成阻塞,那么这样一来我们的主线程UI线程 就会 ...

  8. android 4.0主线程訪问网络问题

    在4.0下面,在主线程中訪问网络,假设请求超过6s的话,就会报ANR,那么这就会带来一个问题,假设网络慢或者请求的数据过大时,界面会卡顿,造成界面灵敏性非常差,因此网络请求一般不能放在主线程中操作,g ...

  9. 解决Android3.0之后不能在主线程中进行HTTP请求

    感谢大佬:https://www.cnblogs.com/falzy/p/5763848.html 在Android3.0以后,会发现,只要是写在主线程(就是Activity)中的HTTP请求,运行时 ...

随机推荐

  1. NFC 与点对点应用

    http://wenku.baidu.com/view/6a7623a28762caaedc33d426.html

  2. 一种全新的MEMS开关——高性能、快速、低能耗以及双稳态

    这种开关最早由申军教授和研究生阮梅春发明,研究生埃里克·朗格卢瓦在简化结构和缩小尺寸上作了探索,黄志林用相同原理做出了MEMS光学镜子开关,曹志良改变设计.材料和工艺后制作出了能同步开关的矩阵.这种M ...

  3. EasyUI选项卡tab页面处理示例

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  4. C app

    1,C 输入输出字符串

  5. sharepoint 2010 使用自定义列表模版创建列表(1)

    我们在使用sharepoint的过程中,发现一个比较好用的功能,就是“将此列表另存为模版”(save list as template),这个功能的作用是,创建一个和当前列表或者文档库一模一样的配置, ...

  6. jquery获取复选框

    Html代码: <input type="checkbox" name="chekItem" /> checkbox1 <br /> & ...

  7. #include <boost/unordered_set.hpp>

    boost.unordered在C++标准容器std::set,std::multiset,std::map和std::multimap的基础上多实现了四个容器:boost::unordered_se ...

  8. pl/sql查询中文乱码

    1.设置系统环境变量 变量名:NLS_LANG 变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK 2.修改注册表 regedit->hkey_local_machine ...

  9. Top k问题(线性时间选择算法)

    问题描述:给定n个整数,求其中第k小的数. 分析:显然,对所有的数据进行排序,即很容易找到第k小的数.但是排序的时间复杂度较高,很难达到线性时间,哈希排序可以实现,但是需要另外的辅助空间. 这里我提供 ...

  10. 深入理解JVM : Java垃圾收集器

    如果说收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现. Java虚拟机规范中对垃圾收集器应该如何实现并没有任何规定,因此不同的厂商.不同版本的虚拟机所提供的垃圾收集器都可能会有很大差 ...