2013-04-25 74 views
0

我想從服務器(WAMP)數據庫中檢索數據,並且我想在單個列表視圖中顯示。我花了很長時間來了解這個最終我實現了,但logcat顯示了幾個android運行時錯誤。我修復了一些錯誤,併發布了一些我無法修復的錯誤。 我的java文件:android logcat中的運行時異常

package com.example.least; 

import java.util.ArrayList; 
import java.util.HashMap; 

import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 

import android.app.ListActivity; 
import android.content.Intent; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ListAdapter; 
import android.widget.ListView; 
import android.widget.SimpleAdapter; 
import android.widget.TextView; 

public class MainActivity extends ListActivity { 

    // url to make request 
    private static String url = "http://localhost/android_connect/final.php"; 

    // JSON Node names 
    private static final String TAG_CONTACTS = "opass"; 
    private static final String TAG_ID = "User_ID"; 

    // contacts JSONArray 
    JSONArray contacts = null; 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     // Hashmap for ListView 
     ArrayList<HashMap<String, String>> contactList = new ArrayList<HashMap<String, String>>(); 

     // Creating JSON Parser instance 
     JSONParser jParser = new JSONParser(); 

     // getting JSON string from URL 
     JSONObject json = jParser.getJSONFromUrl(url); 

     try { 
      // Getting Array of Contacts 
      contacts = json.getJSONArray(TAG_CONTACTS); 

      // looping through All Contacts 
      for(int i = 0; i < contacts.length(); i++){ 
       JSONObject c = contacts.getJSONObject(i); 

       // Storing each json item in variable 
       String id = c.getString(TAG_ID); 

       // Phone number is agin JSON Object 

       // creating new HashMap 
       HashMap<String, String> map = new HashMap<String, String>(); 

       // adding each child node to HashMap key => value 
       map.put(TAG_ID, id); 

       // adding HashList to ArrayList 
       contactList.add(map); 
      } 
     } catch (JSONException e) { 
      e.printStackTrace(); 
     } 


     /** 
     * Updating parsed JSON data into ListView 
     * */ 
     ListAdapter adapter = new SimpleAdapter(this, contactList, 
       R.layout.list_item, 
       new String[] { TAG_ID }, new int[] { 
         R.id.textView1}); 

     setListAdapter(adapter); 

     // selecting single ListView item 
     ListView lv = getListView(); 

     // Launching new screen on Selecting Single ListItem 
     lv.setOnItemClickListener(new OnItemClickListener() { 

      @Override 
      public void onItemClick(AdapterView<?> parent, View view, 
        int position, long id) { 
       // getting values from selected ListItem 
       String name = ((TextView) view.findViewById(R.id.textView1)).getText().toString(); 


       // Starting new intent 
       Intent in = new Intent(getApplicationContext(), SingleMenuItemActivity.class); 
       in.putExtra(TAG_ID, name); 

       startActivity(in); 
      } 
     }); 
    } 

} 

logcat的例外:

04-25 19:35:02.353: D/AndroidRuntime(5650): Shutting down VM 
04-25 19:35:02.353: W/dalvikvm(5650): threadid=1: thread exiting with uncaught exception (group=0x40a71930) 
04-25 19:35:02.393: E/AndroidRuntime(5650): FATAL EXCEPTION: main 
04-25 19:35:02.393: E/AndroidRuntime(5650): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.least/com.example.least.MainActivity}: android.os.NetworkOnMainThreadException 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread.access$600(ActivityThread.java:141) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.os.Handler.dispatchMessage(Handler.java:99) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.os.Looper.loop(Looper.java:137) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread.main(ActivityThread.java:5041) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at java.lang.reflect.Method.invokeNative(Native Method) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at java.lang.reflect.Method.invoke(Method.java:511) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at dalvik.system.NativeStart.main(Native Method) 
04-25 19:35:02.393: E/AndroidRuntime(5650): Caused by: android.os.NetworkOnMainThreadException 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at java.net.InetAddress.lookupHostByName(InetAddress.java:385) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at java.net.InetAddress.getAllByName(InetAddress.java:214) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at com.example.least.JSONParser.getJSONFromUrl(JSONParser.java:39) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at com.example.least.MainActivity.onCreate(MainActivity.java:45) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.Activity.performCreate(Activity.java:5104) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 
04-25 19:35:02.393: E/AndroidRuntime(5650):  ... 11 more 
04-25 19:35:02.603: D/dalvikvm(5650): GC_CONCURRENT freed 211K, 13% free 2588K/2944K, paused 24ms+30ms, total 226ms 

主要Activity.xml文件:

<ListView 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@android:id/list"> 
</ListView> 

所以我是新到Android我與這些類型的錯誤掙扎請幫我修復

+0

post activity_main.xml code – Shiv 2013-04-25 19:05:35

回答

1

問題是Caused by: java.lang.RuntimeException: Binary XML file line #1: You must supply a layout_width attribute.和它在線at com.example.least.MainActivity.onCreate(MainActivity.java:36)

因此檢查您的佈局文件R.layout.activity_main哪裏缺少layout_width屬性。

順便說一句,儘管你是Android的新手,但你至少應該先閱讀logcat,然後再發布到網絡上,因爲在很多情況下(這是其中之一),logcat告訴你錯誤在哪裏以及它是由什麼引起的通過。

-1

問題是,您正在嘗試在創建時進行網絡相關操作。 Android只允許網絡相關的操作,例如從webservice內部線程或AsyncTask獲取值。所以嘗試添加Asynctask或線程