Android 4.1項目:使用新浪微博分享時(shí)報:
android.os.NetworkOnMainThreadException
網(wǎng)上搜索后知道是因為版本問(wèn)題,在4.0之后在主線(xiàn)程里面執行Http請求都會(huì )報這個(gè)錯,也許是怕Http請求時(shí)間太長(cháng)造成程序假死的情況吧。那么網(wǎng)上的朋友也給出了相應的解決方案,這叫上有政策下有對策:
一:在發(fā)起Http請求的Activity里面的onCreate函數里面添加如下代碼:
//詳見(jiàn)StrictMode文檔 StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build()); StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectLeakedSqlLiteObjects().detectLeakedClosableObjects().penaltyLog().penaltyDeath().build());
如果正在做的項目不是Android 4.0的是看不到StrictMode類(lèi)的。我也是用的網(wǎng)上給的com_weibo_android.jar。但是這個(gè)jar包下載下來(lái)的時(shí)候是2.3的,要先轉換成Android 4.0的項目,再在分享對應的ShareActivity的onCreate()函數中添加上面的兩行代碼。這樣就不會(huì )報這個(gè)錯誤了。
二:使用Thread、Runnable、Handler這三個(gè)類(lèi):
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 = msg.getData(); String val = data.getString("value"); Log.i("mylog","請求結果為-->" + val); }}Runnable runnable = new Runnable(){ @Override public void run() { // // TODO: http request. // Message msg = new Message(); Bundle data = new Bundle(); data.putString("value","請求結果"); msg.setData(data); handler.sendMessage(msg); }}
自己走了不少彎路。
總結來(lái)說(shuō),在4.0內必須把html請求的放到線(xiàn)程內。
聯(lián)系客服